Python自动化:批量处理Excel,按要求筛选出数据并存到新表
itomcoil 2025-05-30 15:11 4 浏览
摘要: 你是否曾被重复的数据筛选工作折磨得筋疲力尽。现在,借助Python自动化工具,仅需几秒钟就能完成原本需要上千分钟的工作量,彻底告别了枯燥与低效!
引言
在仓库管理这个看似平凡却又充满挑战的岗位上,微信公众号粉丝小李担任着仓库主管的角色。每月,他都要执行一项看似简单却极其繁琐的任务:从过去几年的每月物品领用表中筛选出老板需要的数据,比如:领用数量大于1000的物品信息。这不仅是一项重复性极高的工作,而且手工操作一次表格就需要几分钟,每年的数据表都是按月存储的,操作一年的数据表就需要重复操作12次,而十年的数据就需要重复120次,耗费的时间累积起来高达上千分钟。
1.小李的挑战
小李在后台留言中描述了他的困境:“每年的数据表我都需要重复操作12次,十年的数据就是120次。这不仅让我感到疲惫,而且效率极低,手工操作一次表格就需要几分钟,累计起来就是上千分钟。”
2.传统方法的局限
在没有自动化工具辅助的情况下,小李的工作流程是这样的:
- 打开每个Excel文件,逐月查找领用数量。
- 手动筛选出领用数量大于1000的物品信息。
- 复制这些信息并粘贴到新的Excel表中。
- 保存并关闭每个文件,然后重复这个过程。
这个过程不仅耗时,而且容易出错,特别是当数据量庞大时,小李需要保持高度的专注力以避免遗漏或错误。
3.Python自动化的解决方案
我们为小李提供了一个Python脚本,这个脚本能够自动按条件筛选数据并保存到新的Excel里。使用pandas库,我们可以快速读取、筛选并合并数据。
import os
from openpyxl import load_workbook
import pandas as pd
from openpyxl.styles import Border, Side, PatternFill, Font, GradientFill, Alignment
def extract_and_select_data(folder_path, dest_dir):
try:
for filename in os.listdir(folder_path):
if filename.endswith('.xlsx'):
src = os.path.join(folder_path, filename)
os.makedirs(dest_dir, exist_ok=True)
dest_file = os.path.join(dest_dir, filename)
wb = load_workbook(src)
data = {} # 储存所有工作表中满足条件的数据,以工作表名称为键
sheet_names = wb.sheetnames
for sheet_name in sheet_names:
ws = wb[sheet_name]
qty_list = []
# 获取G列的数据,并用enumrate给其对应的元素编号
for row in range(2, ws.max_row+1):
qty = ws['G'+str(row)].value
qty_list.append(qty)
qty_idx = list(enumerate(qty_list)) # 用于编号
# 判断数据是否大于1000,然后返回大于1000的数据所对应的行数
row_idx = [] # 用于储存数量大于1000所对应的的行号
for i in range(len(qty_idx)):
if qty_idx[i][1] > 1000:
row_idx.append(qty_idx[i][0]+2)
# 获取满足条件的数据
data_morethan1K = []
for i in row_idx:
data_morethan1K.append(
ws['A'+str(i)+":"+'I'+str(i)])
data[sheet_name] = data_morethan1K
thin = Side(border_style="thin",
color="000000") # 定义边框粗细及颜色
wb = load_workbook("模板.xlsx")
ws = wb.active
for month in data.keys():
ws_new = wb.copy_worksheet(ws) # 复制模板中的工作表
ws_new.title = month
# 将每个月的数据条数逐个取出并写入新的工作表
# 按数据行数计数,每行数据对应9列,所以每行需分别写入9个单元格
for i in range(len(data[month])):
ws_new.cell(
row=i+2, column=1).value = data[month][i][0][0].value
ws_new.cell(
row=i+2, column=2).value = data[month][i][0][1].value
ws_new.cell(
row=i+2, column=3).value = data[month][i][0][2].value
ws_new.cell(
row=i+2, column=4).value = data[month][i][0][3].value.date()
ws_new.cell(
row=i+2, column=5).value = data[month][i][0][4].value
ws_new.cell(
row=i+2, column=6).value = data[month][i][0][5].value
ws_new.cell(
row=i+2, column=7).value = data[month][i][0][6].value
ws_new.cell(
row=i+2, column=8).value = data[month][i][0][7].value
ws_new.cell(
row=i+2, column=9).value = data[month][i][0][8].value
# 设置字号,对齐,缩小字体填充,加边框
# Font(bold=True)可加粗字体
for row_number in range(2, ws_new.max_row+1):
for col_number in range(1, 10):
c = ws_new.cell(
row=row_number, column=col_number)
c.font = Font(size=10)
c.border = Border(
top=thin, left=thin, right=thin, bottom=thin)
c.alignment = Alignment(
horizontal="left", vertical="center", shrink_to_fit=True)
wb.save(dest_file)
except Exception as e:
print(e)
if __name__ == "__main__":
import time
s_t = time.time()
extract_and_select_data("data", "历年领料数量大于1K")
e_t = time.time()
print(f"用时{e_t-s_t}s")
4.效果展示
通过上述脚本,小李现在可以在20秒钟内完成之前需要上千分钟的工作。这个自动化工具不仅提高了效率,还减少了因手动操作导致的错误。更重要的是,它让小李能够将更多的时间和精力投入到更有创造性和战略性的工作上。
结语
Python自动化不仅仅是编程技巧的展示,更是一种工作方式的革新。它能够帮助我们从重复性劳动中解放出来,让我们有更多时间去做更有创造性的工作。小李的故事证明了自动化的力量,希望他的经历能够激励更多的人去探索和利用Python自动化办公的无限可能。
如果你也像小李一样,面临着重复性工作的苦恼,或者对Python脚本的编写有任何疑问,欢迎在评论区留言,我们将为你提供一对一的技术支持!
本文为原创技术文章,转载请标明出处。如果你喜欢本文,别忘了点赞、转发和关注我们的公众号,获取更多技术干货!
数海丹心
大数据和人工智能知识分享与应用
132篇原创内容
公众号
相关推荐
- PHP使用mongo-php-library操作MongoDB数据库的方法
-
1.介绍1.1介绍福哥今天带着大家学习一下使用PHP操作MongoDB数据库的方法,虽然我们的TFLinux早就安装了MongoDB数据库了,但是还没有应用用到MongoDB数据库,福哥打算先给T...
- MongoDB数据库的快速部署和启动(mongodb数据库怎么使用)
-
一、Mongodb介绍常见数据库介绍关系数据库RDBMS设计表结构,通过SQL语句进行操作。连表关系常见的关系型数据库:mysqloracle(商业)DB2(IBM)sqlserver(微软...
- 关于 PHP 启动 MongoDb 找不到指定模块问题
-
前言:最近有一个小demo,需要通过PHP将用户行为记录储存到MongoDB,再用Spark做协同过滤。由于以前处理跨语言交互是通过消息中间件,这次本地使用MongoDB却弄出了几个问...
- Mongodb在Linux上安装教程(mongodb安装教程图解)
-
正文开始:系统环境:linuxcentos7mongodb版本:4.4.0一、下载为了保证各处版本一致性及便捷性,使用官网下载安装包安装官网传送门:https://www.mongodb.com/t...
- MongoDB下载安装(mongodb下载哪个版本)
-
零、参考资料0.1安装https://blog.csdn.net/weixin_45767204/article/details/1301247370.2下载安装失败权限问题:可以看以下这个htt...
- MongoDB入门指南:下载、安装和配置一款强大的NoSQL数据库
-
MongoDB是一种流行的开源NoSQL数据库管理系统,用于存储和处理大规模数据。在本指南中,我将详细介绍如何下载、安装、配置和启动/停止MongoDB服务。下载和安装MongoDB:a.访问Mo...
- MongoDB 从入门到实战:.NET 平台完整指南
-
一、什么是MongoDBMongoDB是一种功能强大且灵活的NoSQL数据库,适用于处理大规模的半结构化数据和高并发场景。它不依赖于固定的表结构和关系模型,而是以文档的形式存储数据,每个文档可...
- CentOS安装MongoDB教程(centos8 mongodb)
-
MongoDB是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似json的bson格式,因此可以存储比较复杂的数据类型。下载...
- MongoDB最全详解(万字图文总结)(mongodb $ne)
-
大家好,我是mikechen。MongoDB是大型互联网架构经常使用到的数据库,各大厂也都会涉及,下面我就全面来详解MongoDB@mikechen作者:mikechen来源:mikechen.ccM...
- MongoDB功能与安装指南(mongodb部署安装)
-
MongoDB主要功能介绍MongoDB是一款开源的NoSQL文档数据库,适用于灵活、高性能和大规模数据存储场景。以下是其核心功能:灵活文档模型数据以BSON(BinaryJSON)文档形...
- 系列二:Anaconda虚拟环境准备(anaconda虚拟环境pycharm)
-
1、打开cmd执行,输入condacreate-nchatglm3python=3.102、激活ChatGLM3condaactivatechatglm3#退出虚拟环境condad...
- 第54节 错误处理及调试-Web前端开发之Javascript-零点程序-王唯
-
本内容是《Web前端开发之Javascript视频》的课件,请配合大师哥《Javascript》视频课程学习。错误处理对于web应用开发至关重要,任何javascript错误都有可能会导致网页无法使用...
- 系列专栏(八):JS的第七种基本类型Symbols
-
ES6作为新一代JavaScript标准,已正式与广大前端开发者见面。为了让大家对ES6的诸多新特性有更深入的了解,MozillaWeb开发者博客推出了《ES6InDepth》系列文章。CSDN...
- JavaScript 运算符(javascript 运算符优先级)
-
运算符=用于赋值。运算符+用于加值。运算符=用于给JavaScript变量赋值。算术运算符+用于把值加起来。实例指定变量值,并将值相加:y=5;z=2;x=y+z;在以上语句...
- JavaScript 变量(javascript 变量传递)
-
变量是用于存储信息的"容器"。实例varx=5;vary=6;varz=x+y;就像代数那样x=5y=6z=x+y在代数中,我们使用字母(比如x)来保存值(比如5)。通过上面的表达式...
- 一周热门
- 最近发表
-
- PHP使用mongo-php-library操作MongoDB数据库的方法
- MongoDB数据库的快速部署和启动(mongodb数据库怎么使用)
- 关于 PHP 启动 MongoDb 找不到指定模块问题
- Mongodb在Linux上安装教程(mongodb安装教程图解)
- MongoDB下载安装(mongodb下载哪个版本)
- MongoDB入门指南:下载、安装和配置一款强大的NoSQL数据库
- MongoDB 从入门到实战:.NET 平台完整指南
- CentOS安装MongoDB教程(centos8 mongodb)
- MongoDB最全详解(万字图文总结)(mongodb $ne)
- MongoDB功能与安装指南(mongodb部署安装)
- 标签列表
-
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)
- shutil.copy() (33)