用python制作一个简单处理Excel表格的小工具(需求)

因为工作上每周都需要制作一份周报,公司有系统可以导出excel表格数据,但是导出来没办法直接用透视表算出最终的通报数据,每次还要进行分列、替换单元格内容、手工换算原始表数据等机械性工作,对身心健康造成严重摧残。所以打算用python做一个小工具解放我的身心。

其实我不做后端技术工作好多年了,而且对python也没系统学习过,只停留在知道有这么个语言工具,简单易用、功能强大。所以这次学习了很多大神的博客分享,帮助我基本完成了这个小工具。我自己的博客只为记录自己的学习过程,没有侵权盗用的恶意。

相关大神的分享地址:
Kanny广小隶,Python制作小软件
vivian_ll,解决maximum recursion depth exceeded in comparison报错
CodingDog,Python 打包成 exe,太大了该怎么解决
通信小黑,利用Python3开发一款小工具

一、需求分析
1、对指定excel表格进行数据预操作:包括分列、替换、列值除法和加法计算;
2、将预处理好的表格作为一个新的sheet保存到原excel工作簿中;
3、通过预处理好的表格生成透视表,也作为一个新的sheet保存到原excel工作簿中;
4、这个小工具最好是能制作成一个exe程序,可以移植到其他电脑上使用;(这点最后基本失败,后面详细说)

好的,我可以为您提供一些实现这个小程序的思路。 1. 安装必要的库 要处理Excel文件,我们需要使用Python的第三方库`openpyxl`,所以首先需要安装该库。可以使用以下命令进行安装: ``` pip install openpyxl ``` 2. 选择Excel文件 您可以使用Python的`tkinter`库来创建一个GUI界面,以便用户选择要拆分的Excel文件。 以下是一个简单的示例代码: ```python import tkinter as tk from tkinter import filedialog root = tk.Tk() root.withdraw() file_path = filedialog.askopenfilename() ``` 3. 解析Excel文件 使用`openpyxl`库打开Excel文件,并将数据存储在Python中以便后续处理。以下是一个示例代码,假设Excel文件中只有一个工作表: ```python from openpyxl import load_workbook wb = load_workbook(filename=file_path) ws = wb.active # 将数据存储在Python中 data = [] for row in ws.iter_rows(values_only=True): data.append(row) ``` 4. 拆分Excel文件 根据用户的需求,您可以选择按行数或列数拆分Excel文件。 以下是按行数拆分Excel文件的示例代码: ```python # 按行数拆分Excel文件 row_num = 100 # 每个文件包含的行数 num_files = (len(data) + row_num - 1) // row_num # 计算需要拆分成的文件数 for i in range(num_files): start_row = i * row_num end_row = min(start_row + row_num, len(data)) file_name = f"{i + 1}.xlsx" wb = Workbook() ws = wb.active # 将数据写入Excel文件 for row in data[start_row:end_row]: ws.append(row) wb.save(file_name) ``` 以下是按列数拆分Excel文件的示例代码: ```python # 按列数拆分Excel文件 col_num = 10 # 每个文件包含的列数 num_files = (len(data[0]) + col_num - 1) // col_num # 计算需要拆分成的文件数 for i in range(num_files): start_col = i * col_num end_col = min(start_col + col_num, len(data[0])) file_name = f"{i + 1}.xlsx" wb = Workbook() ws = wb.active # 将数据写入Excel文件 for row in data: ws.append(row[start_col:end_col]) wb.save(file_name) ``` 5. 创建桌面小程序 您可以使用Python的第三方库`PyQt`或`Tkinter`来创建一个GUI桌面小程序,以便用户更方便地使用拆分Excel文件的功能。其中,`PyQt`的功能比`Tkinter`更强大,但学习曲线也更陡峭。以下是一个使用`Tkinter`库的示例代码: ```python import tkinter as tk from tkinter import filedialog from openpyxl import load_workbook from openpyxl import Workbook class ExcelSplitter: def __init__(self, master): self.master = master master.title("Excel拆分工具") self.file_label = tk.Label(master, text="请选择要拆分的Excel文件:") self.file_label.pack() self.choose_file_button = tk.Button(master, text="选择文件", command=self.choose_file) self.choose_file_button.pack() self.row_option = tk.Radiobutton(master, text="按行数拆分", variable=self.split_method, value="row") self.row_option.pack() self.row_entry = tk.Entry(master) self.row_entry.pack() self.col_option = tk.Radiobutton(master, text="按列数拆分", variable=self.split_method, value="col") self.col_option.pack() self.col_entry = tk.Entry(master) self.col_entry.pack() self.split_button = tk.Button(master, text="拆分文件", command=self.split_file) self.split_button.pack() self.quit_button = tk.Button(master, text="退出", command=master.quit) self.quit_button.pack() self.split_method = tk.StringVar() self.split_method.set("row") def choose_file(self): self.file_path = filedialog.askopenfilename() def split_file(self): if not hasattr(self, "file_path"): return wb = load_workbook(filename=self.file_path) ws = wb.active data = [] for row in ws.iter_rows(values_only=True): data.append(row) if self.split_method.get() == "row": row_num = int(self.row_entry.get()) num_files = (len(data) + row_num - 1) // row_num for i in range(num_files): start_row = i * row_num end_row = min(start_row + row_num, len(data)) file_name = f"{i + 1}.xlsx" wb = Workbook() ws = wb.active for row in data[start_row:end_row]: ws.append(row) wb.save(file_name) elif self.split_method.get() == "col": col_num = int(self.col_entry.get()) num_files = (len(data[0]) + col_num - 1) // col_num for i in range(num_files): start_col = i * col_num end_col = min(start_col + col_num, len(data[0])) file_name = f"{i + 1}.xlsx" wb = Workbook() ws = wb.active for row in data: ws.append(row[start_col:end_col]) wb.save(file_name) root = tk.Tk() my_gui = ExcelSplitter(root) root.mainloop() ``` 希望这些代码对您有所帮助!
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值