老板让我从几百个Excel中查找数据,我用Python一分钟搞定!

 大家好,又到了Python办公自动化系列。

10多年的鄂城网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。成都营销网站建设的优势是能够根据用户设备显示端的尺寸不同,自动调整鄂城建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。创新互联建站从事“鄂城网站设计”,“鄂城网站推广”以来,每个客户项目都认真落实执行。

今天分享一个真实的办公自动化需求,大家一定要仔细阅读需求说明,在理解需求之后即可体会Python的强大!

一、需求说明

首先我们来看下今天的需求,有一份档案记录总表的Excel工作簿, 每天会根据当天日期建立新表,每天的表格内包含所有档案信息,同时也有可能会添加新的档案名。同个年度的总表在年末可能会有两、三百个工作表,同时每个表中可能也存在千余份档案信息。表格形式如下(为了直观呈现本例以7个工作表和十余份档案的形式呈现)

需要完成的操作:为了方便审查特定档案信息,需要给出档案名后生成一份新表,该表包含指定档案在所有日期(即所有工作表)中的记录。最终结果如下(以档案x003为例):

也就是老板说:给我把这几百个表格中所有包含档案x003的相关数据全部找到并整理个新的表格给我!

二、步骤分析

正式写代码前可以把需求分析清楚,将复杂问题简单化。

说白了,这个需求要求把所有日期工作表中的特定行都提取出来整合成一个新表。那么我们可以遍历每一张表,然后遍历第一列(名称列,也可以看作A列)每一个有数据的单元格,如果单元格中的文字为我们需要的档案名,就把这一行提取出来放到新的表格中,进一步梳理步骤为

  • 建立一个新的EXCEL工作簿
  • 新表的表头和档案记录Excel中的一样,也是名称、配置、提交日期等
  • 遍历档案记录Excel的每一张工作表sheet,再遍历第一列每一个有数据的单元格,对内容进行判断
  • 找到符合条件的单元格后获取行号,根据行号将当前表中的特定行提取出来,并将行追加新创建的表中

分析清楚就可以着手写代码了

三、Python实现

首先导入需要的库本例中涉及旧表的打开和新表的创建,因此需要从openpyxl导入load_workbook和Workbook(如果是ppt和word用到的模块就更智能了,一个方法就能搞定)

 
 
 
 
  1. from openpyxl import load_workbook, Workbook 

接着导入旧表及创建新表

 
 
 
 
  1. # 从桌面上获取总表 
  2. filepath = r'C:\Users\chenx\Desktop\台账.xlsm' # 根据实际情况进行修改 
  3. workbook = load_workbook(filepath) 
  4. # 创建新的Excel工作簿获取到工作表 
  5. new_workbook = Workbook() 
  6. new_sheet = new_workbook.active 
  7.  
  8. # 给新表写入表头 
  9. new_headers = ['名称', '配置', '提交日期', '受限操作', '操作时间', '状态', '存储位置'] 
  10. new_sheet.append(new_headers) 

现在是核心步骤:多次遍历,可以用workbook.sheetnames获取工作簿所有工作表名称的列表,然后遍历即可

 
 
 
 
  1. for i in workbook.sheetnames: 
  2.     sheet = workbook[i] 
  3.     # 获取档案名称所在列 
  4.     names = sheet['A'] 

按照前面的分析,需要遍历名称列,判断每一个单元格的值是不是需要的档案名。这里应注意,如果已经循环到需要的单元格,就可以停止循环了,但一定要把符合单元格的行号传递给一个变量做记录,不然一旦break出循环就没有记忆了

 
 
 
 
  1. flag = 0 
  2. for cell in names: 
  3. if cell.value == keyword: # 这里的keyword就是档案名,可以以 档案x003 为例 
  4.     flag = cell.row 
  5.     break 

获得到符合条件的行号后用sheet[flag]就可以拿到符合行了。openpyxl不支持旧表的一整行写入新表,因此应对策略就是将这一行的所有单元格具体值组装成一个列表,用sheet.append(列表)的方法写入新表,遍历部分的完整代码如下:

 
 
 
 
  1. for i in workbook.sheetnames: 
  2.     sheet = workbook[i] 
  3.     names = sheet['A'] 
  4.     flag = 0 
  5.     for cell in names: 
  6.         if cell.value == keyword: 
  7.             flag = cell.row 
  8.             break 
  9.     if flag:   # 如果flag没有被修改则不需要顺序进行下列代码 
  10.         data_lst = [] 
  11.         for cell in sheet[flag]: 
  12.             # 这里加上一个对内容的判断,是让无内容的行直接放空,而不是写入一个 none 
  13.             if cell.value:   
  14.                 data_lst.append(str(cell.value)) 
  15.             else: 
  16.                 data_lst.append(' ') 
  17.         new_sheet.append(data_lst) 

最后记得保存

 
 
 
 
  1. new_workbook.save(r'C:\Users\chenx\Desktop\台账查询.xlsx') 

小结

这是经过一定改编的真实案例,可见Python自动化办公确实能够帮助我们解放自己的双手,不过在写自动化脚本之前也要先拆分任务,明确思路再进行,如果对本文的代码和数据感兴趣可以在后台回复自动化获取。最后还是希望大家能够理解Python办公自动化的一个核心就是批量操作-解放双手,让复杂的工作自动化!

文章名称:老板让我从几百个Excel中查找数据,我用Python一分钟搞定!
转载注明:http://www.csdahua.cn/qtweb/news5/237755.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网