Python在不同场景合并多个Excel的方法

作者:??Python研究者???? 时间:2021-11-03 02:52:00 

前言

三种场景

  • 多个同字段的excel文件合并成一个excel

  • 多个不同字段的excel文件拼接成一个excel

  • 一个excel的多个sheet合并成一个sheet

辰哥目前想到的仅是辰哥遇到的这三种情况

01 合并多个同字段的excel

这里辰哥先新建三个excel文件:11.xlsx;12.xlsx;13.xlsx;并往里填充数据,数据如下:

1.xlsx

Python在不同场景合并多个Excel的方法

1.xlsx

Python在不同场景合并多个Excel的方法

1.xlsx

Python在不同场景合并多个Excel的方法

需求:将这三个excel文件合并到一个excel中。

导入库:

# 读取模块
import xlrd
# 写入模块
import xlwt

这里需要用到两个库:xlrd读取excel; xlwt写入到合并的excel;

# 文件列表
xlxs_list = ["1/11.xlsx","1/12.xlsx","1/13.xlsx"]
# 创建合并后的文件
workbook = xlwt.Workbook(encoding='ascii')
worksheet = workbook.add_sheet('Sheet1')

定义合并哪些excel文件,以及合并后的excel:

# 行数
count = 0
#表头(只写入第一个xlsx的表头)
bt = 0
for name in xlxs_list:
   wb = xlrd.open_workbook(name)
   #按工作簿定位工作表
   sh = wb.sheet_by_name('Sheet1')
   #遍历excel,打印所有数据
   if count>1:
       bt=1
   for i in range(bt,sh.nrows):
       k = sh.row_values(i)
       # 遍历每一行中的每一列
       for j in range(0,len(k)):
           worksheet.write(count,j, label=str(k[j]))
       count = count +1
workbook.save('1/合并1_辰哥.xlsx')

最后合并到:**合并1_辰哥.xlsx  **中,其结果如下:

Python在不同场景合并多个Excel的方法

02 拼接多个不同字段的excel

新建三个excel文件:21.xlsx;22.xlsx;23.xlsx;并往里填充数据

1.xlsx

Python在不同场景合并多个Excel的方法

2.xlsx

Python在不同场景合并多个Excel的方法

3.xlsx

Python在不同场景合并多个Excel的方法

将这三个excel文件拼接带一个excel中(从左往右)

# 列数
col = 0
for name in xlxs_list:
   wb = xlrd.open_workbook(name)
   #按工作簿定位工作表
   sh = wb.sheet_by_name('Sheet1')
   #遍历excel,打印所有数据
   for i in range(0,sh.nrows):
       k = sh.row_values(i)
       # 遍历每一行中的每一列
       for j in range(0,len(k)):
           worksheet.write(i,col+j, label=str(k[j]))
   col = col +len(k)
workbook.save('2/合并2_辰哥.xlsx')

最后合并到:**合并2_辰哥.xlsx  **中,其结果如下:

Python在不同场景合并多个Excel的方法

03 合并一个excel的多个sheet

新建一个excel文件:31.xlsx;并新增sheet1、sheet2、sheet3,往里填充数据

sheet1

Python在不同场景合并多个Excel的方法

sheet2

Python在不同场景合并多个Excel的方法

sheet3

Python在不同场景合并多个Excel的方法

将同一个excel文件中的这三个sheet并到一个sheet中。

sheet_list = ['Sheet1','Sheet2','Sheet3']
# 行数
count = 0
# 表头(只写入第一个xlsx的表头)
bt = 0
for st in sheet_list:
   #按工作簿定位工作表
   sh = wb.sheet_by_name(st)
   #遍历excel,打印所有数据
   if count > 1:
       bt = 1
   for i in range(bt, sh.nrows):
       k = sh.row_values(i)
       # 遍历每一行中的每一列
       for j in range(0, len(k)):
           worksheet.write(count, j, label=str(k[j]))
       count = count + 1
workbook.save('3/合并3_辰哥.xlsx')

最后合并到:合并3_辰哥.xlsx 中,其结果如下:

Python在不同场景合并多个Excel的方法

来源:https://juejin.cn/post/6994717630485495815

标签:Python,合并,Excel,方法
0
投稿

猜你喜欢

  • python同时给两个收件人发送邮件的方法

    2021-10-23 07:31:36
  • Python使用multiprocessing创建进程的方法

    2022-08-03 14:09:21
  • python 输入一个数n,求n个数求乘或求和的实例

    2022-06-06 01:44:36
  • python中str内置函数用法总结

    2022-06-23 10:22:45
  • python爬虫框架scrapy代理中间件掌握学习教程

    2021-03-22 15:34:54
  • Python 常用模块threading和Thread模块之线程池

    2022-02-20 05:39:08
  • SQL优化基础 使用索引(一个小例子)

    2012-01-29 18:29:26
  • 用户凭什么跟你注册?

    2011-06-10 13:16:00
  • 网页设计:把导航系统做薄

    2007-12-28 12:02:00
  • python代码有一行标黄问题的解决方案

    2021-07-16 22:29:57
  • 谈谈FACEBOOK的一处产品细节

    2008-03-11 11:05:00
  • python爬虫用mongodb的理由

    2023-09-27 23:06:40
  • 解决Keras TensorFlow 混编中 trainable=False设置无效问题

    2022-10-23 16:56:19
  • 常见Dreamweaver使用过程中的问题及解决办法

    2011-03-17 16:16:00
  • Python按行读取文件的实现方法【小文件和大文件读取】

    2021-12-11 01:31:08
  • Python + selenium + crontab实现每日定时自动打卡功能

    2021-06-10 19:45:42
  • Yii2 rbac权限控制之菜单menu实例教程

    2023-11-14 10:41:19
  • python实现括号匹配的思路详解

    2023-08-24 16:50:30
  • 利用global.asa计划执行程序

    2008-03-05 12:49:00
  • PHP比你想象的好得多

    2023-11-20 09:33:30
  • asp之家 网络编程 m.aspxhome.com