使用 wxPython和ECharts生成和保存HTML图表

使用wxPython和ECharts库来生成和保存HTML图表。wxPython是一个基于wxWidgets的Python GUI库,而ECharts是一个用于数据可视化的JavaScript库。
C:\pythoncode\blog\echartshow.py
在这里插入图片描述
参考网址:https://echarts.apache.org/v4/examples/zh/index.html

安装依赖

在开始之前,我们需要确保已经安装了必要的依赖库。你可以使用以下命令来安装wxPython和ECharts库:

pip install wxPython

创建应用程序窗口

首先,让我们来创建一个应用程序窗口,作为图表生成和保存的界面。

import wx
import wx.html2 as webview

class MainFrame(wx.Frame):
    def __init__(self):
        super().__init__(None, title="HTML Viewer", size=(800, 600))
        self.panel = wx.Panel(self)

        # 创建GUI组件
        self.echart_memo = wx.TextCtrl(self.panel, style=wx.TE_MULTILINE)
        self.button_generate = wx.Button(self.panel, label="生成")
        self.button_save = wx.Button(self.panel, label="保存")
        self.web = None

        # 绑定事件处理函数
        self.button_generate.Bind(wx.EVT_BUTTON, self.on_generate)
        self.button_save.Bind(wx.EVT_BUTTON, self.on_save)

        # 创建布局
        sizer = wx.BoxSizer(wx.VERTICAL)
        sizer.Add(self.echart_memo, proportion=1, flag=wx.EXPAND)
        sizer.Add(self.button_generate, flag=wx.EXPAND)
        sizer.Add(self.button_save, flag=wx.EXPAND)

        self.panel.SetSizer(sizer)

在上述代码中,我们创建了一个名为MainFrame的类,它继承自wx.Frame。在构造函数中,我们创建了用于输入ECharts选项的文本框、生成和保存图表的按钮,并将它们添加到一个垂直布局的面板中。

生成和保存图表

接下来,我们将实现生成和保存图表的功能。

    def on_generate(self, event):
        echart_options = self.echart_memo.GetValue()

        if self.web is not None:
            self.web.Destroy()

        self.web = webview.WebView.New(self.panel, -1, parent=self.panel, style=wx.NO_BORDER)
        sizer = self.panel.GetSizer()
        sizer.Add(self.web, proportion=1, flag=wx.EXPAND)
        self.panel.Layout()

        # 构建完整的HTML文件
        html = f'''
        <html>
        <head>
            <script src="https://cdn.jsdelivr.net/npm/echarts@5.2.2/dist/echarts.min.js"></script>
            <script type="text/javascript">
                var chartDom = document.getElementById('echart-container');
                var myChart = echarts.init(chartDom);
                var option = {echart_options};
                myChart.setOption(option);
            </script>
        </head>
        <body>
            <div id="echart-container" style="width: 100%; height: 400px;"></div>
        </body>
        </html>
        '''

        self.web.SetPage(html, "")

    def on_save(self, event):
        echart_options = self.echart_memo.GetValue()

        # 构建完整的HTML文件
        html = f'''
        <html>
        <head>
            <script src="https://cdn.jsdelivr.net/npm/echarts@5.2.2/dist/echarts.min.js"></script>
            <script type="text/javascript">
                var chartDom = document.getElementById('echart-container');
                var myChart = echarts.init(chartDom);
                var option = {echart_options};
                myChart.setOption(option);
            </script>
        </head>
        <body>
            <div id="echart-container" style="width: 100%; height: 400px;"></div>
        </body>
        </html>
        '''

        # 保存HTML文件
        current_datetime = datetime.datetime.now().strftime("%Y%m%d_%H%M%S")
        file_path = f"./html/{current_datetime}.html"
        with open(file_path, "w") as file:
            file.write(html)

        wx.MessageBox(f"保存成功!文件路径:{file_path}", "保存成功", wx.OK | wx.ICON_INFORMATION)

在上述代码中,我们定义了on_generateon_save两个方法。on_generate方法在用户点击"生成"按钮时被调用,它从文本框中获取ECharts选项,并根据选项动态生成包含图表的HTML字符串。然后,我们使用wxWebView组件将HTML字符串加载到应用程序窗口中,以显示生成的图表。

on_save方法在用户点击"保存"按钮时被调用,它与on_generate方法类似,但还将生成的HTML字符串保存为一个HTML文件。文件名使用当前时间戳来确保每个文件具有唯一名称。保存成功后,我们使用wx.MessageBox显示一个消息框,通知用户保存操作成功,并显示保存的文件路径。

运行应用程序

最后,我们创建一个wx.App实例,实例化MainFrame类,并运行应用程序的事件循环。

if __name__ == "__main__":
    app = wx.App()
    frame = MainFrame()
    frame.Show()
    app.MainLoop()

以上代码片段创建了一个wx.App实例,并初始化了应用程序的GUI。然后,我们显示主窗口,并通过调用app.MainLoop()方法启动应用程序的事件循环,使应用程序保持运行状态。
完整代码:

import wx
import wx.html2 as webview
import datetime


class MainFrame(wx.Frame):
    def __init__(self):
        super().__init__(None, title="HTML Viewer", size=(800, 600))
        self.panel = wx.Panel(self)

        self.echart_memo = wx.TextCtrl(self.panel, style=wx.TE_MULTILINE)
        self.button_generate = wx.Button(self.panel, label="生成")
        self.button_save = wx.Button(self.panel, label="保存")
        self.web = webview.WebView.New(self.panel)

        self.button_generate.Bind(wx.EVT_BUTTON, self.on_generate)
        self.button_save.Bind(wx.EVT_BUTTON, self.on_save)

        sizer = wx.BoxSizer(wx.VERTICAL)
        sizer.Add(self.echart_memo, proportion=1, flag=wx.EXPAND)
        sizer.Add(self.button_generate, flag=wx.EXPAND)
        sizer.Add(self.button_save, flag=wx.EXPAND)
        sizer.Add(self.web, proportion=1, flag=wx.EXPAND)

        self.panel.SetSizer(sizer)

    def on_generate(self, event):
        echart_options = self.echart_memo.GetValue()

        # 构建完整的HTML文件
        html = f'''
         <html>
        <head>
            <script src="https://cdn.jsdelivr.net/npm/echarts@5.2.2/dist/echarts.min.js"></script>

        </head>
        <body>
            <div id="chart-container" style="width: 100%; height: 400px;"></div>
                        <script>              
                var chart = echarts.init(document.getElementById('chart-container'));
                var  {echart_options}
                chart.setOption(option);
            </script>
        </body>
        </html>
        '''

        self.web.SetPage(html, "")

    def on_save(self, event):
        echart_options = self.echart_memo.GetValue()

        # 构建完整的HTML文件
        # html = f'''
        html = f'''
         <html>
        <head>
            <script src="https://cdn.jsdelivr.net/npm/echarts@5.2.2/dist/echarts.min.js"></script>

        </head>
        <body>
            <div id="chart-container" style="width: 100%; height: 400px;"></div>
                        <script>              
                var chart = echarts.init(document.getElementById('chart-container'));
                var  {echart_options}
                chart.setOption(option);
            </script>
        </body>
        </html>
        '''

        # 保存HTML文件
        current_datetime = datetime.datetime.now().strftime("%Y%m%d_%H%M%S")
        file_path = f"../html/{current_datetime}.html"
        with open(file_path, "w") as file:
            file.write(html)

        wx.MessageBox(f"保存成功!文件路径:{file_path}", "保存成功", wx.OK | wx.ICON_INFORMATION)


if __name__ == '__main__':
    app = wx.App()
    frame = MainFrame()
    frame.Show()
    app.MainLoop()

结论

本篇博客介绍了如何使用wxPython和ECharts库来生成和保存HTML图表。通过结合wxPython的GUI组件和ECharts的数据可视化功能,我们可以轻松创建一个图表生成和保存工具。用户只需输入ECharts选项,点击生成按钮即可在应用程序窗口中实时查看图表,并能够将图表保存为HTML文件以供进一步使用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/76954.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

2023最新水果编曲软件FL Studio 21.1.0.3267音频工作站电脑参考配置单及系统配置要求

音乐在人们心中的地位日益增高&#xff0c;近几年音乐选秀的节目更是层出不穷&#xff0c;喜爱音乐&#xff0c;创作音乐的朋友们也是越来越多&#xff0c;音乐的类型有很多&#xff0c;好比古典&#xff0c;流行&#xff0c;摇滚等等。对新手友好程度基本上在首位&#xff0c;…

区间预测 | MATLAB实现QRLSTM长短期记忆神经网络分位数回归时间序列区间预测

区间预测 | MATLAB实现QRLSTM长短期记忆神经网络分位数回归时间序列区间预测 目录 区间预测 | MATLAB实现QRLSTM长短期记忆神经网络分位数回归时间序列区间预测效果一览基本介绍模型描述程序设计参考资料 效果一览 基本介绍 MATLAB实现QRLSTM长短期记忆神经网络分位数回归时间序…

解决内网GitLab 社区版 15.11.13项目拉取失败

问题描述 GitLab 社区版 发布不久&#xff0c;搭建在内网拉取项目报错&#xff0c;可能提示 unable to access https://github.comxxxxxxxxxxx: Failed to connect to xxxxxxxxxxxxxGit clone error - Invalid argument error:14077438:SSL routines:SSL23_GET_S 15.11.13ht…

ATF(TF-A)安全通告 TFV-5 (CVE-2017-15031)

安全之安全(security)博客目录导读 ATF(TF-A)安全通告汇总 目录 一、ATF(TF-A)安全通告 TFV-5 (CVE-2017-15031) 二、CVE-2017-15031 一、ATF(TF-A)安全通告 TFV-5 (CVE-2017-15031) Title 未初始化或保存/恢复PMCR_EL0可能会泄露安全世界的时间信息 CVE ID CVE-2017-1503…

支持https访问

文章目录 1. 打开自己的云服务器的 80 和 443 端口2. 安装 nginx3. 安装 snapd4. 安装 certbot5. 生成证书6. 拷贝生成的证书到项目工作目录7. 修改 main.go 程序如下8. 编译程序9. 启动程序10. 使用 https 和端口 8081 访问页面成功11. 下面修改程序&#xff0c;支持 https 和…

Rust软件外包开发语言的特点

Rust 是一种系统级编程语言&#xff0c;强调性能、安全性和并发性的编程语言&#xff0c;适用于广泛的应用领域&#xff0c;特别是那些需要高度可靠性和高性能的场景。下面和大家分享 Rust 语言的一些主要特点以及适用的场合&#xff0c;希望对大家有所帮助。北京木奇移动技术有…

分布式 - 消息队列Kafka:Kafka 消费者的消费位移

文章目录 01. Kafka 分区位移02. Kafka 消费位移03. kafka 消费位移的作用04. Kafka 消费位移的提交05. kafka 消费位移的存储位置06. Kafka 消费位移与消费者提交的位移07. kafka 消费位移的提交时机08. Kafka 维护消费状态跟踪的方法 01. Kafka 分区位移 对于Kafka中的分区而…

Linux系统安装Google Chrome

1.进入谷歌浏览器官网 Google Chrome - Download the Fast, Secure Browser from GoogleGet more done with the new Google Chrome. A more simple, secure, and faster web browser than ever, with Google’s smarts built-in. Download now.http://www.google.cn/intl/en_…

rust入门系列之Rust介绍及开发环境搭建

Rust教程 Rust基本介绍 网站: https://www.rust-lang.org/ rust是什么 开发rust语言的初衷是&#xff1a; 在软件发展速度跟不上硬件发展速度&#xff0c;无法在语言层面充分的利用硬件多核cpu不断提升的性能和 在系统界别软件开发上&#xff0c;C出生比较早&#xff0c;内…

零售行业供应链管理核心KPI指标(三)

完美订单满足率和退货率 完美订单满足率有三个方面的因素影响&#xff1a;订单按时、足量、无损交货。通常情况下零售企业追求线上订单履行周期慢慢达到行业平均水平&#xff0c;就是交付的速度变快了&#xff0c;这个肯定是一件好事情&#xff0c;趋势越来越好。 同时&#…

周期 角频率 频率 振幅 初相角

周期 角频率 频率 振幅 初相角 当我们谈论傅里叶级数或波形分析时&#xff0c;以下术语经常出现&#xff1a; 周期 T T T: 函数在其图形上重复的时间或空间的长度。周期的倒数是频率。 频率 f f f: 周期的倒数&#xff0c;即一秒内波形重复的次数。单位通常为赫兹&#xff…

【NLP】训练LLM的不同方式

一、说明 在大型语言模型&#xff08;LLM&#xff09;领域&#xff0c;有各种各样的 训练机制&#xff0c;具有不同的手段&#xff0c;要求和目标。由于它们服务于不同的目的&#xff0c;因此重要的是不要将它们相互混淆&#xff0c;并了解它们适用的不同场景。 在本文中&#…

JavaWeb-Listener监听器

目录 监听器Listener 1.功能 2.监听器分类 3.监听器的配置 4.ServletContext监听 5.HttpSession监听 6.ServletRequest监听 监听器Listener 1.功能 用于监听域对象ServletContext、HttpSession和ServletRequest的创建&#xff0c;与销毁事件监听一个对象的事件&#x…

智能数据建模软件DTEmpower 2023R2新版本功能介绍

DTEmpower是由天洑软件自主研发的一款通用的智能数据建模软件&#xff0c;致力于帮助工程师及工科专业学生&#xff0c;利用工业领域中的仿真、试验、测量等各类数据进行挖掘分析&#xff0c;建立高质量的数据模型&#xff0c;实现快速设计评估、实时仿真预测、系统参数预警、设…

什么是LAXCUS分布式操作系统?

相较Linux、Windows&#xff0c;Laxcus是同时在多台计算机上运行的操作系统&#xff0c;处理大规模、高并发、高性能业务&#xff0c;其特点是资源共享和任务并行&#xff0c;并实现【数存算管】超融合一体化。环境中的资源&#xff1a;CPU、GPU、内存、硬盘、网络&#xff0c;…

C++之类之间访问函数指针(一百八十一)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 人生格言&#xff1a; 人生…

k8s 自身原理之高可用

说到高可用&#xff0c;咱们在使用主机环境的时候&#xff08;非 k8s&#xff09;&#xff0c;咱做高可用有使用过这样的方式&#xff1a; 服务器做主备部署&#xff0c;当主节点和备节点同时存活的时候&#xff0c;只有主节点对外提供服务&#xff0c;备节点就等着主节点挂了…

如何用树莓派Pico针对IoT编程?

目录 一、Raspberry Pi Pico 系列和功能 二、Raspberry Pi Pico 的替代方案 三、对 Raspberry Pi Pico 进行编程 硬件 软件 第 1 步&#xff1a;连接计算机 第 2 步&#xff1a;在 Pico 上安装 MicroPython 第 3 步&#xff1a;为 Thonny 设置解释器 第 4 步&#xff…

单片机第一季:零基础13——AD和DA转换

1&#xff0c;AD转换基本概念 51 单片机系统内部运算时用的全部是数字量&#xff0c;即0 和1&#xff0c;因此对单片机系统而言&#xff0c;无法直接操作模拟量&#xff0c;必须将模拟量转换成数字量。所谓数字量&#xff0c;就是用一系列0 和1 组成的二进制代码表示某个信号大…

Java之SpringCloud Alibaba【四】【微服务 Sentinel服务熔断】

Java之SpringCloud Alibaba【四】【微服务 Sentinel服务熔断】 一、分布式系统遇到的问题1、服务挂掉的一些原因 二、解决方案三、Sentinel&#xff1a;分布式系统的流量防卫兵1、Sentinel是什么2、Sentinel和Hystrix对比3、Sentinel快速开发4、通过注解的方式来控流5、启动Sen…