Python | Dashboard制作

运行环境:jupyter notebook (python 3.12.7) + Pyecharts

1.安装pyecharts

python 复制代码
!pip install pyecharts

验证安装是否成功:

python 复制代码
from pyecharts import __version__
print("Pyecharts版本:", __version__)  # 应显示1.x以上版本

2.运行基础版代码,生成深/浅色双模式HTML

python 复制代码
from pyecharts.charts import Line, Bar, Pie, Scatter, Page
from pyecharts import options as opts
import random

# 生成示例数据
categories = ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
data1 = [random.randint(20, 100) for _ in range(7)]
data2 = [random.randint(30, 150) for _ in range(7)]
pie_data = [('A', 45), ('B', 30), ('C', 25)]
scatter_data = [(i, random.randint(10, 50)) for i in range(20)]

# 创建 Page 实例
page = Page(layout=Page.SimplePageLayout)

# 折线图(添加固定ID)
line = (
    Line(init_opts=opts.InitOpts(chart_id="chart_line"))
    .add_xaxis(categories)
    .add_yaxis("Series 1", data1, is_smooth=True)
    .add_yaxis("Series 2", data2, is_smooth=True)
    .set_global_opts(
        title_opts=opts.TitleOpts(title="Weekly Trend"),
        toolbox_opts=opts.ToolboxOpts(),
        tooltip_opts=opts.TooltipOpts(trigger="axis")
    )
)

# 柱状图(添加固定ID)
bar = (
    Bar(init_opts=opts.InitOpts(chart_id="chart_bar"))
    .add_xaxis(categories)
    .add_yaxis("Sales", data1, color="#5793f3")
    .add_yaxis("Profit", data2, color="#d14a61")
    .set_global_opts(
        title_opts=opts.TitleOpts(title="Sales vs Profit"),
        datazoom_opts=opts.DataZoomOpts(),
        toolbox_opts=opts.ToolboxOpts()
    )
)

# 饼图(添加固定ID)
pie = (
    Pie(init_opts=opts.InitOpts(chart_id="chart_pie"))
    .add("", pie_data, radius=["30%", "55%"])
    .set_global_opts(
        title_opts=opts.TitleOpts(title="Market Share"),
        legend_opts=opts.LegendOpts(orient="vertical", pos_top="15%", pos_left="2%")
    )
    .set_series_opts(label_opts=opts.LabelOpts(formatter="{b}: {d}%"))
)

# 散点图(添加固定ID)
scatter = (
    Scatter(init_opts=opts.InitOpts(chart_id="chart_scatter"))
    .add_xaxis([x[0] for x in scatter_data])
    .add_yaxis("Value", [y[1] for y in scatter_data])
    .set_global_opts(
        title_opts=opts.TitleOpts(title="Scatter Distribution"),
        toolbox_opts=opts.ToolboxOpts(),
        visualmap_opts=opts.VisualMapOpts(max_=50)
    )
)

# 将图表添加到 Page
page.add(line, bar, pie, scatter)

# 生成初始 HTML
page.render("dashboard.html")

# ------------- 手动添加交互功能 --------------
def insert_theme_switcher():
    """向生成的 HTML 中插入主题切换组件"""
    with open("dashboard.html", "r", encoding="utf-8") as f:
        html = f.read()

    insert_code = f"""
    <!-- 主题切换按钮 -->
    <div style="position: fixed; top: 20px; right: 20px; z-index: 9999; background: white; padding: 10px; border-radius: 5px; box-shadow: 0 2px 10px rgba(0,0,0,0.1);">
        <button onclick="changeTheme('light')">☀️ 明亮模式</button>
        <button onclick="changeTheme('dark')">🌙 暗黑模式</button>
    </div>
    <script>
    // 存储图表配置
    var chartConfigs = {{
        chart_line: {line.dump_options()},
        chart_bar: {bar.dump_options()},
        chart_pie: {pie.dump_options()},
        chart_scatter: {scatter.dump_options()}
    }};

    // 主题切换函数
    function changeTheme(theme) {{
        ['chart_line', 'chart_bar', 'chart_pie', 'chart_scatter'].forEach(chartId => {{
            let chart = echarts.getInstanceByDom(document.getElementById(chartId));
            if (chart) chart.dispose();
            let newChart = echarts.init(
                document.getElementById(chartId), 
                theme,
                {{ renderer: 'canvas' }}
            );
            newChart.setOption(chartConfigs[chartId]);
        }});
    }}
    </script>
    """

    # 在 </body> 前插入代码
    new_html = html.replace("</body>", insert_code + "\n</body>")
    with open("dashboard.html", "w", encoding="utf-8") as f:
        f.write(new_html)

insert_theme_switcher()
print("仪表盘生成成功!打开 dashboard.html 查看效果")

HTML截图:

相关推荐
用户83562907805110 小时前
Python 实现 PDF 文件加密与解密方法
后端·python
用户83562907805111 小时前
使用 Python 冻结与拆分 Excel 窗格教程
后端·python
你好潘先生19 小时前
别再记命令了,用 yeero do 说句人话就能跑脚本,而且不烧 token
服务器·python·命令行
Agent_大师19 小时前
WebSocket 行情重连成功,K线缺口不会自动消失
python
荣码19 小时前
LLM结构化输出:让AI返回JSON而不是废话,我踩了4个坑
java·python
copyer_xyf19 小时前
FastAPI 如何连接 MySQL
后端·python
apocelipes1 天前
常用编程语言和库的正则表达式性能对比
c语言·c++·python·性能优化·golang·开发工具和环境
用户8356290780511 天前
使用 Python 在 PDF 中创建与管理书签
后端·python
MeixianAgent2 天前
Python 回测数据入口怎么验?历史 K 线入库前先做 5 个检查
后端·python
咕白m6252 天前
用 Python 实现一键批量查找与替换 Excel 数据
后端·python