使用wxPython和pandas模块生成Excel文件

介绍:

在Python编程中,有时我们需要根据特定的数据生成Excel文件。本文将介绍如何使用wxPython和pandas模块来实现这个目标。我们将创建一个简单的GUI应用程序,允许用户选择输出文件夹和输入的Excel文件,并根据Excel文件中每个单元格的字段名组合生成多个Excel文件。
C:\pythoncode\new\genxlsbyxls.py
1. 准备工作

在开始之前,确保您已经安装了wxPython和pandas模块。如果没有安装,可以使用以下命令进行安装:

pip install wxPython
pip install pandas

2. 创建GUI窗口

首先,我们需要创建一个GUI窗口,以便用户可以选择输出文件夹和输入的Excel文件。我们将使用wxPython模块来创建窗口和按钮,并将事件与相应的回调函数关联起来。

import wx
import os
import pandas as pdclass MyFrame(wx.Frame):def __init__(self, parent, title):super(MyFrame, self).__init__(parent, title=title, size=(400, 200))panel = wx.Panel(self)self.output_dir_btn = wx.Button(panel, label="选择输出文件夹")self.Bind(wx.EVT_BUTTON, self.on_select_output_dir, self.output_dir_btn)self.input_file_btn = wx.Button(panel, label="选择Excel文件")self.Bind(wx.EVT_BUTTON, self.on_select_input_file, self.input_file_btn)self.start_btn = wx.Button(panel, label="开始生成")self.Bind(wx.EVT_BUTTON, self.on_start_generation, self.start_btn)sizer = wx.BoxSizer(wx.VERTICAL)sizer.Add(self.output_dir_btn, 0, wx.ALL|wx.EXPAND, 5)sizer.Add(self.input_file_btn, 0, wx.ALL|wx.EXPAND, 5)sizer.Add(self.start_btn, 0, wx.ALL|wx.EXPAND, 5)panel.SetSizer(sizer)def on_select_output_dir(self, event):dlg = wx.DirDialog(self, "选择输出文件夹", style=wx.DD_DEFAULT_STYLE)if dlg.ShowModal() == wx.ID_OK:self.output_dir = dlg.GetPath()print("输出文件夹:", self.output_dir)dlg.Destroy()def on_select_input_file(self, event):dlg = wx.FileDialog(self, "选择Excel文件", wildcard="Excel files (*.xlsx)|*.xlsx",style=wx.FD_OPEN | wx.FD_FILE_MUST_EXIST)if dlg.ShowModal() == wx.ID_OK:self.input_file = dlg.GetPath()print("输入文件:", self.input_file)dlg.Destroy()def on_start_generation(self, event):if not hasattr(self, 'output_dir') or not hasattr(self, 'input_file'):wx.MessageBox("请先选择输出文件夹和Excel文件", "错误", wx.OK | wx.ICON_ERROR)returndf = pd.read_excel(self.input_file)for i, col in enumerate(df.iloc[:, 0]):column_names = col.split(',')file_name = f"{i+1}.xlsx"file_path = os.path.join(self.output_dir, file_name)df_new = pd.DataFrame(columns=column_names)df_new.to_excel(file_path, index=False)wx.MessageBox("生成完成", "提示", wx.OK | wx.ICON_INFORMATION)self.Close()app = wx.App()
frame = MyFrame(None, "Excel文件生成器")
frame.Show()
app.MainLoop()```在上述代码中,我们创建了一个`MyFrame`类,继承自wxPython的`Frame`类。该类表示我们的应用程序窗口,并包含了选择输出文件夹和选择Excel文件的按钮。**3. 实现回调函数**接下来,我们需要实现与按钮关联的回调函数。这些函数将在用户点击相应的按钮时被调用。```pythondef on_select_output_dir(self, event):dlg = wx.DirDialog(self, "选择输出文件夹", style=wx.DD_DEFAULT_STYLE)if dlg.ShowModal() == wx.ID_OK:self.output_dir = dlg.GetPath()print("输出文件夹:", self.output_dir)dlg.Destroy()def on_select_input_file(self, event):dlg = wx.FileDialog(self, "选择Excel文件", wildcard="Excel files (*.xlsx)|*.xlsx",style=wx.FD_OPEN | wx.FD_FILE_MUST_EXIST)if dlg.ShowModal() == wx.ID_OK:self.input_file = dlg.GetPath()print("输入文件:", self.input_file)dlg.Destroy()def on_start_generation(self, event):if not hasattr(self, 'output_dir') or not hasattr(self, 'input_file'):wx.MessageBox("请先选择输出文件夹和Excel文件", "错误", wx.OK | wx.ICON_ERROR)returndf = pd.read_excel(self.input_file)for i, col in enumerate(df.iloc[:, 0]):column_names = col.split(',')file_name = f"{i+1}.xlsx"file_path = os.path.join(self.output_dir, file_name)df_new = pd.DataFrame(columns=column_names)df_new.to_excel(file_path, index=False)wx.MessageBox("生成完成", "提示", wx.OK | wx.ICON_INFORMATION)self.Close()

在上述代码中,on_select_output_dir函数用于选择输出文件夹,并将选择的路径存储在self.output_dir变量中。on_select_input_file函数类似地用于选择输入的Excel文件,并将选择的文件路径存储在self.input_file变量中。

on_start_generation函数是最重要的回调函数。它首先读取选择的Excel文件,并逐个单元格解析字段名组合。然后,根据字段名组合创建新的DataFrame,并将其保存为一个新的Excel文件,文件名为序号加上.xlsx后缀。生成的Excel文件将保存在选择的输出文件夹中。

4. 运行应用程序

最后,我们需要创建一个wx.App对象并运行应用程序的主循环。

app = wx.App()
frame = MyFrame(None, "Excel文件生成器")
frame.Show()
app.MainLoop()

这段代码创建了一个wx.App对象和一个MyFrame对象,并将应用程序的主循环交给app.MainLoop()处理。

5. 效果演示
在这里插入图片描述

在这里插入图片描述

现在,我们已经完成了整个程序的编写。运行程序后,将会出现一个GUI窗口,您可以通过点击按钮选择输出文件夹和输入的Excel文件。当您点击"开始生成"按钮后,程序将根据Excel文件中的字段名组合生成多个Excel文件,并保存在指定的输出文件夹中。

这个程序提供了一个简单而实用的方法来根据Excel文件中的字段名组合生成多个Excel文件。您可以根据自己的需求进行修改和扩展,以满足更复杂的场景。

总结:

本文介绍了如何使用wxPython和pandas模块创建一个简单的GUI应用程序,用于根据Excel文件中的字段名组合生成多个Excel文件。通过选择输出文件夹和输入的Excel文件,程序能够自动解析字段名组合,并生成对应的Excel文件。这种方法可以方便地处理大量数据,并将其保存为易于管理和使用的Excel文件。


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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

docker jenkins 部署springboot项目

1、创建jenkins容器 1,首先,我们需要创建一个 Jenkins 数据卷,用于存储 Jenkins 的配置信息。可以通过以下命令创建一个数据卷: docker volume create jenkins_data启动 Jenkins 容器并挂载数据卷: docker run -dit…

算法-并查集

目录 什么是并查集 并查集基础 (1)原理 (2)初始化 (3)查询 (4)合并 (5)判断是否同一集合 并查集优化 路径压缩 启发式合并 并查集模板 模板 例题…

C#修改默认参数settings文件

右击项目在设置中进行修改: 千万不要在这里改。 如果要在自己的项目里添加这个文件,首先新建个文件夹,然后添加.setting文件,然后再像上面说的那样添加属性。

4.请求体

什么是请求体(Request Body) 请求体是客户端发送到API的数据。 响应体是API发送给客户端的数据 API几乎总是必须发送一个响应体,但是客户端并不需要一直发送请求体 定义请求体,需要使用 Pydantic 模型 不能通过GET请求发送请求体发送请求体数据&…

常见的容器技术有哪些

容器技术是一种轻量级的软件封装方式,它将软件代码及其依赖项打包在一起,这样应用可以在任何支持容器的系统上无缝运行。它允许应用程序及其依赖项在一个隔离的环境中运行,这个环境被称为容器。容器技术有助于提高应用程序的可移植性、一致性…

深度学习之基于Tensorflow卷积神经网络智能体操健身系统

欢迎大家点赞、收藏、关注、评论啦 ,由于篇幅有限,只展示了部分核心代码。 文章目录 一项目简介 二、功能三、系统四. 总结 一项目简介 一、项目背景 随着人们健康意识的提高和数字化技术的快速发展,智能健身系统逐渐成为健身领域的新趋势。…

Redis之Linux下的安装配置

Redis之Linux下的安装配置 Redis下载 Linux下下载源码安装配置 方式一 官网下载:https://redis.io/download ​ 其他版本下载:https://download.redis.io/releases/ 方式二(推荐) GitHub下载:https://github.com/r…

景源畅信:个人抖音小店怎么开通?

在数字时代的浪潮中,个体创业已不再是遥不可及的梦想。特别是随着短视频平台的崛起,抖音不仅成为人们娱乐消遣的新宠,更是众多创业者眼中的“新大陆”。你是否也曾憧憬过在抖音上开一家属于自己的小店?那么,如何开通个人抖音小店…

java—异常

异常 什么是异常 异常的体系 编译时异常处理方式 1、选择报错的整个代码块,快捷键crtlaltt键,选择try/catch将代码围起来。 2、编译异常处理方式2 在main方法上抛出异常 自定义异常 例子: 自定义运行时异常 自定义编译时异常 异常…

QT截图程序,可多屏幕截图

截图程序&#xff0c;支持多屏幕时跨屏幕截图。截图使用setMask达到镂空效果&#xff0c;截图后会有预览和保存功能。截图时按下Esc可退出。 mainwindow.ui mainwindow.cpp #include "mainwindow.h" #include "ui_mainwindow.h" #include <QDebug> …

Ansible自动化运维工具 - playbook 剧本编写

一. inventory 主机清单 Inventory 支持对主机进行分组&#xff0c;每个组内可以定义多个主机&#xff0c;每个主机都可以定义在任何一个或多个主机组内。 1.1 inventory 中的变量含义 Inventory 变量名 含义ansible_hostansible连接节点时的IP地址ansible_port连接对方…

2024-05-07 商业分析-如何在社会层面做一个更好的工具人-记录

摘要: 2024-05-07 商业分析-如何成为一个靠谱的工具人 如何在社会层面做一个更好的工具人 那么今天讲的这个主题呢&#xff0c;对吧&#xff1f;你们一看啊&#xff0c;就觉得这个就不应该我讲是吧啊&#xff0c;但是呢这个逻辑呢我还得跟你们讲一下啊&#xff0c;就是如何成为…

虚幻引擎笔记

虚幻引擎笔记 一、蓝图类二、创建自定义Character蓝图三、操作映射和轴映射 一、蓝图类 Actor&#xff1a;可以放置在关卡中的物体Pawn&#xff1a;相当于游戏角色&#xff0c;可以通过玩家控制器来控制角色&#xff1a;在Pawn的基础上增加了四处走动的功能。创建游戏角色时使用…

Freeswitch-mod开发

文章目录 一、Freeswitch-mod开发1.1 介绍1.2 实战1.2.1 新建一个mymod.c或者mymod.cpp1.2.2 新建一个Makefile1.2.3 编译 二、Freeswitch-mod-自定义Dialplan模块2.1 介绍2.2 实战2.2.1 改造mymod.c&#xff08;代码是完整的&#xff0c;自己做区别看一下&#xff09;2.2.2 编…

python实验三 实现UDP协议、TCP协议进行服务器端与客户端的交互

实验三 实验题目 1、请利用生成器构造一下求阶乘的函数Factorial()&#xff0c;定义一个函数m()&#xff0c;在m()中调用生成器Factorial()生成小于100的阶乘序列存入集合s中&#xff0c;输出s。 【代码】 def factorial():n1f1while 1:​ f * n​ yield (f)​ n1…

XORM 框架的使用

1、xorm 1.1、xorm 简介 xorm 是一个简单而强大的Go语言ORM库. 通过它可以使数据库操作非常简便。 特性 支持 struct 和数据库表之间的灵活映射&#xff0c;并支持自动同步事务支持同时支持原始SQL语句和ORM操作的混合执行使用连写来简化调用支持使用ID, In, Where, Limit,…

Python批量计算多张遥感影像的NDVI

本文介绍基于Python中的gdal模块&#xff0c;批量基于大量多波段遥感影像文件&#xff0c;计算其每1景图像各自的NDVI数值&#xff0c;并将多景结果依次保存为栅格文件的方法。 如下图所示&#xff0c;现在有大量.tif格式的遥感影像文件&#xff0c;其中均含有红光波段与近红外…

通过氧气退火增强β-Ga₂O₃二极管.中国科技大学和河北半导体研究所的研究人员在这一特定领域取得了最新重大进展

上图所示&#xff1a;&#xff08;a&#xff09;增加台面有助于提高β-Ga2O3肖特基势垒二极管的阻断电压&#xff08;b&#xff09;。 氧气退火和自对准台面终端使β-Ga2O3二极管进一步走向商业化。 虽然β-Ga2O3电力电子技术已经取得了长足的进步&#xff0c;但仍然存在挑战&…

QT creator qt6.0 使用msvc2019 64bit编译报错

qt creator qt6.0报错&#xff1a; D:\Qt6\6.3.0\msvc2019_64\include\QtCore\qglobal.h:123: error: C1189: #error: "Qt requires a C17 compiler, and a suitable value for __cplusplus. On MSVC, you must pass the /Zc:__cplusplus option to the compiler."…

VTK —— 三、简单操作 - 示例3 - 将点投影到平面上(附完整源码)

代码效果 本代码编译运行均在如下链接文章生成的库执行成功&#xff0c;若无VTK库则请先参考如下链接编译vtk源码&#xff1a; VTK —— 一、Windows10下编译VTK源码&#xff0c;并用Vs2017代码测试&#xff08;附编译流程、附编译好的库、vtk测试源码&#xff09; 教程描述 本…