【问题标题】:How to add a local image (svg / png) to plotly layout?如何将本地图像(svg / png)添加到绘图布局?
【发布时间】:2021-02-11 07:30:19
【问题描述】:

我知道这个问题有几个答案,但没有一个能让我满意,因为它们都包含Dash,而我只想使用基本的plotly

我有一个本地图像文件:/tmp/bla.svg(还有/tmp/bla.svg),我想在我的图表上显示为徽标:

这是我的图形代码,使用来自 plotly 的示例:

    fig.add_layout_image(
        dict(
            source='https://raw.githubusercontent.com/cldougl/plot_images/add_r_img/vox.png',
            xref='paper', yref='paper',
            x=1, y=1.05,
            sizex=0.1, sizey=0.1,
            xanchor='center', yanchor='bottom'
        )
    )

这很好用,但是任何将源更改为本地图像的尝试都会失败。该文档甚至没有提供非网址图像源的选项。

我确实尝试了本地网址 - 但失败了:

source=r'file:///tmp/bla.png',

还有

source=r'file:///tmp/bla.svg',

我也尝试过使用this answer - using base64 encoding:

def _get_image(path):
    with open(path, 'rb') as image_file:
        encoded_string = base64.b64encode(image_file.read()).decode()
    encoded_img = f'data:image/png;base64,{encoded_string}'
    return encoded_img
...
source=_get_image(path)
...

但这也失败了,即使我测试了输出 base64,它是一个图像!

我怎样才能让它工作?

【问题讨论】:

  • 你的环境是什么? jupyter?、spyder?、vscode?
  • 不知道它是如何连接的。不过,我有一个解决方案 - 我稍后会发布。我最终设法使用了 svg 文件的 base64 编码,然后将其作为 url,没有枕头 :)
  • @CIsForCookies 您的解决方案有什么更新吗?我有兴趣申请它
  • @KansaiRobot 我只是将它读入一个变量然后它就起作用了。猜猜我在解码图像时弄乱了一些东西。我的代码现在看起来像:figure.add_layou_image(dict(source='data:image/svg+xml;base64,...', ...))。希望对你有帮助

标签: python svg plotly


【解决方案1】:

对于本地文件,您可以使用 pillow(或类似的)读取文件,然后将其用作 plotly 的源。

from PIL import Image
pyLogo = Image.open("python-logo.png")

就我而言,python-logo.png 与我的笔记本位于同一文件夹中。

完整示例(改编自here):

import plotly.graph_objects as go
import plotly.io as pio
from PIL import Image

# to render in jupyterlab
pio.renderers.default = "plotly_mimetype"

# Create figure
fig = go.Figure()

pyLogo = Image.open("python-logo.png")

# Add trace
fig.add_trace(
    go.Scatter(x=[0, 0.5, 1, 2, 2.2], y=[1.23, 2.5, 0.42, 3, 1])
)

fig.add_layout_image(
        dict(
            source=pyLogo,
            xref="x",
            yref="y",
            x=0,
            y=3,
            sizex=2,
            sizey=2,
            sizing="stretch",
            opacity=0.5,
            layer="below")
)

fig.show()

【讨论】:

    猜你喜欢
    • 2012-07-14
    • 2019-05-04
    • 1970-01-01
    • 2021-04-09
    • 1970-01-01
    • 1970-01-01
    • 2015-04-14
    • 2021-10-16
    • 2019-09-28
    相关资源
    最近更新 更多