一篇梳理清楚使用Python根据原始Excel表格批量生成目标Excel表格

开发 前端
如果是正常操作的话,肯定是点击进去Excel文件,然后每个单元格进行复制,然后粘贴到新文件,然后保存,之后重命名。

大家好,我是Python进阶者。

一、前言

前几天在帮助粉丝解决问题的时候,遇到一个简单的小需求,这里拿出来跟大家一起分享,后面再次遇到的时候,可以从这里得到灵感。

二、需求澄清

粉丝的问题来源于实际的需求,下图是原始数据,需要在1-3处填充另外一个表格中的数据:

图片

如果是正常操作的话,肯定是点击进去Excel文件,然后每个单元格进行复制,然后粘贴到新文件,然后保存,之后重命名。

这样做肯定是可以,但是当有上百个文件夹需要复制呢?上千个文件呢?肯定就需要消耗大量的时间和精力了。估计一天都不一定完成的了。

这里使用Python进行批量实现!

三、实现过程

这里给大家提供一个可行的代码,思路也很简单,openpyxl库进行实现,代码如下:

import openpyxl

workbook1 = openpyxl.load_workbook("模板.xlsx")
worksheet1 = workbook1.worksheets[0]
print(worksheet1['C4'].value) # 金额
print(worksheet1['D4'].value) # 公司
print(worksheet1['F4'].value) # 编号

workbook2 = openpyxl.load_workbook("订单.xlsx")
worksheet2 = workbook2[0]
print(worksheet2['C3'].value) # 城市
print(worksheet2['D3'].value) # 编号
print(worksheet2['CU3'].value) # 金额
print(worksheet2['DM3'].value) # 公司

print(f"正在处理订单:{worksheet2['C3'].value}...")
worksheet1['C4'].value = worksheet2['CU3'].value
worksheet1['D4'].value = f"{worksheet2['DM3'].value}分公司"
worksheet1['F4'].value = worksheet2['D3'].value
new_file_name = f"({worksheet2['C3'].value} {worksheet2['D3'].value})"
workbook1.save(new_file_name + '.xlsx')
print(f"订单:{worksheet2['C3'].value}处理完成")

代码运行之后,就可以实现该Excel文件中对应的数据替换了。不过这里只是单个文件的替换。

如果想要批量的进行替换的话,则需要加入for循环,如下所示:

for i in range(len(worksheet.row)):
print(f"正在第{i}行,处理订单:{worksheet2[f'C{i}'].value}...")
worksheet1['C4'].value = worksheet2[f'CU{i}'].value
worksheet1['D4'].value = f"{worksheet2[f'DM{i}'].value}分公司"
worksheet1['F4'].value = worksheet2[f'D{i}'].value
new_file_name = f"({worksheet2[f'C{i}'].value} {worksheet2[f'D{i}'].value})"
workbook1.save(new_file_name + '.xlsx')
time.sleep(3)
print(f"订单:{worksheet2[f'C{i}'].value}处理完成")

三、总结

大家好,我是皮皮。这篇文章主要盘点一个Python自动化办公的实用案例,这个案例可以适用于实际工作中文件处理,大家也可以稍微改进下,用于自己的实际工作中去,举一反三。通过这个案例,大家应该学习到了很多,我相信应该还有其他更好的方法,欢迎大家留言区留言。

责任编辑:武晓燕 来源: Python爬虫与数据挖掘
相关推荐

2023-01-11 18:23:38

传统数仓Hadoop数仓技术

2024-10-23 08:00:00

PythonExcel数据分析

2021-06-21 05:23:21

Excel消除Excel表格密码技巧

2012-07-19 15:54:14

2022-01-04 09:53:37

Python多线程多进程

2022-07-05 09:24:01

Pandas表格样式Python

2020-11-06 08:28:44

Python

2024-03-15 10:29:54

PyQt6Python表格视图

2021-04-08 05:58:45

Excel数据技巧

2017-12-17 20:17:23

NoSQLSQL数据

2018-08-13 09:20:21

NoSQLSQL数据

2011-03-30 09:29:52

2015-07-21 16:48:51

Excel表格

2020-10-18 07:49:40

开源在线表格Excel前端表格库

2020-10-16 12:05:39

GitHub 技术开源

2022-05-31 06:07:45

Excel表Python

2020-02-03 09:02:39

工具代码开发

2024-07-15 15:05:20

Python数据驱动

2018-09-26 16:04:04

NVMe主机控制器

2022-04-27 09:09:57

架构师术语技术语言
点赞
收藏

51CTO技术栈公众号