2014-09-26 41 views
13

我有一个ipython笔记本,它具有来自本地驱动器的嵌入式图像。我期待它与代码单元的输出一起嵌入到JSON中,但是当我分发笔记本时,图像不会显示给用户。在Notebook中嵌入图像的推荐方法是什么,以便在用户重新运行代码单元,清除单元输出等时不会消失?将图像嵌入到ipython笔记本中进行发布

笔记本电脑系统缓存了包含在![label](image.png)中的图像,但它们只持续到服务笔记本的python“内核”重新启动为止。如果我在磁盘上重命名图像文件,我可以关闭并重新打开笔记本,并且它仍然显示图像;但是当我重新启动内核时它会消失。

编辑:如果我生成图像作为代码细胞输出然后导出笔记本到html,图像被嵌入在HTML作为编码数据。当然,必须有办法挂钩到这个功能,并将输出加载到markdown(或更好的“原始nbconvert”)单元格中?

from IPython.display import Image 
Image(filename='imagename.png') 

将出口(与ipython nbconvert)为HTML,它包含以下内容:

<div class="output_png output_subarea output_execute_result"> 
<img src="... 
</div> 

然而,即使我手动嵌入段成降价细胞,我不能得到要显示的图像。我究竟做错了什么?

PS现有(旧)答案给出了一些非常有用的指针,但不是解决方案。

+0

可惜没有人在这段时间内回答过这个问题!现在有没有解决方案? – alexis 2015-04-22 14:10:28

+0

我遇到了完全相同的问题。显然,进入' tel 2015-10-01 06:03:38

+0

Yeah, that's reasonable, and I had expected some sort of filter. Actually I'd be surprised if originally there was no filter at all-- it's more likely that was just strengthened in version 2. But the question is still, _is_ there some method that gets past the filters? – alexis 2015-10-01 15:32:10

回答

5

你是否乐意使用额外的代码单元来显示图像?如果是这样,使用此:

from IPython.display import Image 
Image(filename="example.png") 

输出单元将具有嵌入.ipynb文件中的原始图像数据,这样你就可以分享和图像将被保留。

注意,Image类也有一个url关键字,但这只会链接到图像,除非你也指定embed=True(见documentation了解详细信息)。因此,除非您指的是远程服务器上的映像,否则使用filename关键字更为安全。

如果您需要将图像包含在Markdown单元中,即没有单独的代码单元来生成嵌入的图像数据,我不确定是否有简单的解决方案。您可以使用python markdown extension,它允许在降价单元格中动态显示Python变量的内容。但是,该扩展会动态生成降格单元,因此为了在共享笔记本时保留输出,需要使用“安装”一节中提到的预处理器pymdpreprocessor.py运行ipython nbconvert --to notebook original_notebook.ipynb --output preprocessed_notebook。生成的笔记本将数据作为格式为<img src="data:image/png;base64,...">的HTML标签嵌入到降格单元中,因此您可以从preprocessed_notebook.ipynb中删除相应的代码单元格。不幸的是,当我尝试这个时,<img>标签的内容实际上并没有显示在浏览器中,所以不确定这是否是一个可行的解决方案。 : -/

不同的选择是在代码单元中使用Image类生成上面的图像,然后使用nbconvert和自定义模板从笔记本中删除代码输入单元。详情请参阅this thread。但是,这将剥离所有来自转换笔记本的代码单元,因此它可能不是您想要的。

+0

Thanks! I don't _require_ the image to be in a markdown cell, but using code is (a) distracting, since the code cell cannot be hidden; and (b) more crucially, it's unsafe because these are notebooks for programming practice and the user can be expectedto clear cell outputs now and then. – alexis 2015-05-04 17:04:40

+0

PS. Thanks for the nbconvert thread... I've been gradually piling up my own conversion scripts because nbconvert's guts are completely opaque (and not very well documented). Maybe this will lead me to a source of better explanations. – alexis 2015-05-04 17:08:05

+0

Not sure if this is relevant, but maybe [this example](https://github.com/maxalbert/auto-exec-notebook) can also be helpful to better understand 'nbconvert' and automated notebook execution. I haven't looked at it in detail, but in my limited experience the nbconvert machinery seems to be relatively tidy in the latest version of IPython (and potentially simpler than in previous versions due to the simplification of the notebook format itself). – cilix 2015-05-04 19:03:43

2

之所以当你把它放在一个降价细胞中

<img src="... 

标签没有做任何事情,是因为IPython中使用HTML清洁剂(一种叫做Google Caja)是筛选出这个类型的标签(和许多其他)在它可以被呈现之前。

在IPython中的HTML消毒剂可以通过添加下面一行到你的custom.js文件(通常位于~/.ipython/profile_default/static/custom/custom.js)被完全禁用:

iPython.security.sanitize_html = function (html) { return html; }; 

这不是一个很好的解决方案,虽然,因为它带来安全风险,这对分配并没有太大的帮助。

后记
呈现base64编码字符串作为图像=明显的安全问题,所以应该有卡哈人最终允许这类事情的经过(虽然the related feature request ticket第一次打开背部的方式的能力!在2012年,所以不要屏住呼吸)。

+1

That's a good lead! Notebooks have a concept of "trusted" notebook, implemented (I think) as a cryptographic key once a notebook has been inspected by the user. The reasonable thing to do would be to relax html sanitizing for trusted notebooks. Any ideas on how this could be set up? – alexis 2015-10-01 18:43:26

+1

@alexis *le sigh* I tried that too. Clicking though the 'File -> Trust Notebook'菜单对话框的原因似乎不会以某种方式影响HTML清理。不过,你说得对。我想它必须在IPython代码库中实现。也许你或我会考虑提交拉取请求? – tel 2015-10-01 20:49:38

+0

不是我,我不知道如何在受信任的属性(或实际放置的位置)上设置此条件。我不确定完全禁用消毒是否正确 - 应该有更大的功能白名单通过。如果你有足够的兴趣去做,我会非常好奇,看看开发者是否接受了这个想法! – alexis 2015-10-02 12:07:59

相关问题