分享

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

 wxsjbcf 2021-08-09

大家好,我是辰哥~

在辰哥看来,技术能够减少繁琐工作带来的枯燥,技术+实际=方便。最近辰哥也是在弄excel文件的时候发现手动去整理有点繁琐枯燥,想着技术可以代替我去处理这部分繁琐的工作那何乐而不为呢~~~

三种场景

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

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

  3. 一个excel的多个sheet合并成一个sheet

辰哥目前想到的仅是辰哥遇到的这三种情况(如果还有很多其他情况的,欢迎在下方留言,因为辰哥日常非经常涉及多种excel处理的内容,所以想不到其他情况)

01


合并多个同字段的excel

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

11.xlsx

图片

12.xlsx

图片

13.xlsx

图片

需求:将这三个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 = 0for 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 +1workbook.save('1/合并1_辰哥.xlsx')

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

图片

02


拼接多个不同字段的excel

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

21.xlsx

图片

22.xlsx

图片

23.xlsx

图片

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

# 列数col = 0for 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  中,其结果如下:

图片

03


合并一个excel的多个sheet

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

sheet1

图片

sheet2

图片

sheet3

图片

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

sheet_list = ['Sheet1','Sheet2','Sheet3']# 行数count = 0# 表头(只写入第一个xlsx的表头)bt = 0for 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 + 1workbook.save('3/合并3_辰哥.xlsx')

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

图片

04


小结

目前想到的仅是辰哥遇到的这三种情况(如果还有很多其他情况的,欢迎在下方留言,因为辰哥日常并非经常涉及多种excel处理的内容,所以想不到其他情况)

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多