python不到50行代码完成了多张excel合并的实现示例

作者:知识追寻者 时间:2023-04-11 10:41:39 

一 前言

公司同事最近在做excel相关的工作;今天来求助知识追寻者合并多个excel为一个一个工作本,原本是java操作poi太蛋疼了,笨重不堪,内存消耗严重,知识追寻者使用python不到40行代码完成了60多张excel工作本合并为一张;python真香

牛皮吹完了,如果看过知识追寻者系列文章的读者肯定知道之前知识追寻者发过一篇

python专题使用openpyxl操作excel;本篇使用的不是openpyx库,使用的使是xlrd,xlwt库,虽然这两库功能没法根openpyx相比,但可以操作xls结尾的旧版excel而openpyx不支持;

二 代码

大体思路如下

  • 遍历获取根目录下的所有excel文件

  • 根据excel名称进行匹配获取某类excel

  • 创建工作本用于写入拷贝的数据

  • 每个excel都有一张Sheet1,循环遍历单元格写入创建的工作本

详细过程写在代码里面;读者可以参考一下思路和使用方式,后续知识追寻者有空会出这2库基础系列文章的使用方式;


# -*- coding: utf-8 -*-
import xlrd
import xlwt
import os
import re

""" 写入工作本 """
def write_excel(path, write_sheet):
 # 加载工作本
 book = xlrd.open_workbook(path)
 # 获取表单
 read_sheet = book.sheet_by_name('Sheet1')
 # 遍历
 for row in range(read_sheet.nrows):
   for col in range(read_sheet.ncols):
     write_sheet.write(row, col, read_sheet.cell_value(row,col))

# 获取根目录下所有文件名
def walk(path):
for root,dirs,names in os.walk(path):
 list = []
 for filename in names:
   path = os.path.join(root, filename)
   list.append(path)
 return list

if __name__ == "__main__":
 # 创建工作本
 write_book = xlwt.Workbook()
 # 根目录
 root = r'C:\mydata\generator\excel'
 path_list = walk(root)
 for path in path_list:
   val = path.find("本专科")
   if val!=-1:
    # 正则匹配
     ser = re.search('.*20200403(.*?).xls',path)
     name = ser.group(1)
     # 创建sheet
     write_sheet = write_book.add_sheet(name)
     # 写入
     write_excel(path, write_sheet)
 # 保存    
 write_book.save(r'本专科.xls')

来源:https://blog.csdn.net/youku1327/article/details/105300668

标签:python,excel,合并
0
投稿

猜你喜欢

  • python发送伪造的arp请求

    2022-11-24 00:47:35
  • PHP保留两位小数的几种方法

    2023-11-15 05:17:54
  • Python词法结构

    2022-01-10 00:33:21
  • pip和pygal的安装实例教程 <font color=red>原创</font>

    2021-05-22 18:35:30
  • 对Pycharm创建py文件时自定义头部模板的方法详解

    2022-06-05 15:24:06
  • Python实现删除文件中含“指定内容”的行示例

    2022-01-15 02:56:28
  • python调用DLL与EXE文件截屏对比分析

    2022-06-01 08:19:15
  • python实现连续变量最优分箱详解--CART算法

    2023-01-15 16:33:05
  • 使用SQLSERVER 2005/2008 递归CTE查询树型结构的方法

    2024-01-27 15:13:10
  • mysqlreport显示Com_中change_db占用比例高的问题的解决方法

    2024-01-26 03:17:38
  • Python的组合模式与责任链模式编程示例

    2023-05-08 07:03:43
  • TensorFlow神经网络构造线性回归模型示例教程

    2023-07-18 08:35:13
  • 有关Oracle数据库的备份情况

    2010-07-30 13:21:00
  • python爬虫基础教程:requests库(二)代码实例

    2023-05-31 07:56:35
  • Mysql数据库表中为什么有索引却没有提高查询速度

    2024-01-13 19:25:16
  • Python从数据库读取大量数据批量写入文件的方法

    2024-01-27 14:48:10
  • 通过python实现windows桌面截图代码实例

    2023-11-19 03:46:27
  • MySQL prepare语句的SQL语法

    2024-01-20 03:14:08
  • Python中的type与isinstance的区别详解

    2021-12-06 19:30:57
  • python读取文件夹中图片的图片名并写入excel表格

    2021-09-10 07:38:38
  • asp之家 网络编程 m.aspxhome.com