在Jupyter Notebook中使用Pyecharts渲染图表时,解决render_notebook()方法无法正常显示的问题

问题描述

在jupyter notebook中使用pyecharts库渲染图表,render()方法可正常在本地生成.html文件,使用render_notebook()方法想要直接在notebook界面显示渲染图表无法正常显示,显示空白。

作者版本

python --3.8.15
pyecharts --2.0.06

简单举例

​
from pyecharts.charts import Line
from pyecharts import options as opts

# 假设我们有以下数据
x_data = ["衬衫", "羊毛衫", "雪纺衫", "裤子", "高跟鞋", "袜子"]
y_data = [5, 20, 36, 10, 10, 100]

# 创建折线图
line = Line()
line.add_xaxis(x_data)
line.add_yaxis("商品销量", y_data)
line.set_global_opts(title_opts=opts.TitleOpts(title="折线图示例"))

# 在 Jupyter Notebook 中展示图表
line.render_notebook()

​

结果显示

问题原因

1.echarts图表

在 Jupyter Notebook 中使用 Pyecharts 或其他 JavaScript 依赖的库时,可能会遇到这个问题。Notebook 中缺少echarts图表基本的JavaScript文件,导致图表渲染不出来。

2.pyecharts库环境配置

当你在jupyer环境中使用Pyecharts库时,Pyecharts 需要知道它运行在哪种类型的笔记本环境中,以便正确地输出图表。

解决方法

1.问题一

在原来代码后添加语句,加载基本的JavaScript到notebook中。

line.load_javascript()

2.问题二

在原来代码前添加语句,配置当前环境以便在 Jupyter Lab 中使用 Pyecharts。

# 从 pyecharts.globals 模块导入 CurrentConfig 和 NotebookType 类
from pyecharts.globals import CurrentConfig, NotebookType

# 设置 CurrentConfig 的 NOTEBOOK_TYPE 属性为 NotebookType.JUPYTER_LAB,
# 以便在 Jupyter Lab 环境中正确渲染 Pyecharts 图表
CurrentConfig.NOTEBOOK_TYPE = NotebookType.JUPYTER_LAB
  • CurrentConfig 是一个全局配置类,用于设置 Pyecharts 的各种配置选项。
  • NotebookType 是一个枚举类,用于指定 Pyecharts 应该在哪种笔记本环境中运行。
  • 效果展示

    1.完整代码

    1.先注释掉line.render_notebook(),运行代码。

    ​
    from pyecharts.charts import Line
    from pyecharts import options as opts
    
    from pyecharts.globals import CurrentConfig, NotebookType
    CurrentConfig.NOTEBOOK_TYPE = NotebookType.JUPYTER_LAB
    # 假设我们有以下数据
    x_data = ["衬衫", "羊毛衫", "雪纺衫", "裤子", "高跟鞋", "袜子"]
    y_data = [5, 20, 36, 10, 10, 100]
    
    # 创建折线图
    line = Line()
    line.add_xaxis(x_data)
    line.add_yaxis("商品销量", y_data)
    line.set_global_opts(title_opts=opts.TitleOpts(title="折线图示例"))
    
    # 在 Jupyter Notebook 中展示图表
    line.load_javascript()
    #line.render_notebook()
    
    ​

    2.解除注释,完整运行。

    ​
    from pyecharts.charts import Line
    from pyecharts import options as opts
    
    from pyecharts.globals import CurrentConfig, NotebookType
    CurrentConfig.NOTEBOOK_TYPE = NotebookType.JUPYTER_LAB
    # 假设我们有以下数据
    x_data = ["衬衫", "羊毛衫", "雪纺衫", "裤子", "高跟鞋", "袜子"]
    y_data = [5, 20, 36, 10, 10, 100]
    
    # 创建折线图
    line = Line()
    line.add_xaxis(x_data)
    line.add_yaxis("商品销量", y_data)
    line.set_global_opts(title_opts=opts.TitleOpts(title="折线图示例"))
    
    # 在 Jupyter Notebook 中展示图表
    line.load_javascript()
    line.render_notebook()
    
    ​

    2.运行结果

     注意事项

    1.在同一个 Notebook 文件中,echarts图表基本的JavaScript文件平常只需加载一次就可以了,后续的图表生成只需直接渲染到 Notebook 即可,而不需要再重复写 load_javascript() 语句了。
    2.如果后续遇到渲染不出的情况,需再次使用load_javascript() 加载所需 js 文件。
    3.如果你在 Jupyter Notebook 中使用 Pyecharts,你应该将 NotebookType.JUPYTER_LAB 替换为 NotebookType.JUPYTER_NOTEBOOK。
    4.问题二中的配置代码,应该在渲染任何 Pyecharts 图表之前执行,以确保配置生效。如果你在设置 CurrentConfig.NOTEBOOK_TYPE 之前尝试渲染图表,可能会遇到渲染问题。

    总结

    个人认为这是比较简单的解决方法,欢迎评论区讨论。

    作者:T_YMS

    物联沃分享整理
    物联沃-IOTWORD物联网 » 在Jupyter Notebook中使用Pyecharts渲染图表时,解决render_notebook()方法无法正常显示的问题

    发表回复