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

目录

前言

三种场景

  • 多个同字段的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的方法

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容