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

大家好,我是辰哥~

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

三种场景

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

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

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

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

01

合并多个同字段的excel

这里辰哥先新建三个excel文件:11.xlsx;12.xlsx;13.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.xlsx;22.xlsx;23.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)

相关推荐

  • 普通小白学会Python到底具体能做什么呢?

    为什么那些教Python课程的人不用Python去做技术赚钱? 就像顶级的运动员们都会有很多训练师指导他们训练,训练师们具备专业知识.专业技能,却不会自己上场比赛,原因有二:其一是黄金年龄段已经过了, ...

  • 史上最全Python 操作 Excel库总结!

    为了带大家了解各个库的异同,从而在不同场景下可以灵活使用,本文将横向比较7个可以操作 Excel 文件的常用模块,在比较各模块常用操作的同时进行巩固学习! 首先让我们来整体把握下不同库的特点 &quo ...

  • Excel VBA工作薄 7.10 不规则数据的合并-针对指定列数据进行合并

    前景提要 通过上一节的学习,我们成功实现了将多个工作表的规则或者不规则数据合并到一个工作表的操作,这两个功能的能够在一定程度上满足大家的日常工作需要,提升我们的工作效率,避免出现重复简单的机械操作的情 ...

  • Python提取多张excel表上的数据,合并汇总到一张新表

    本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理 以下文章来源于财会学习联盟,作者:我是刀哥啊 私信回复"资料" ...

  • Python | 合并检测

    引言本题为2020年蓝桥杯的题,接下来我们将运用python将其解决.问题描述最近存在A病,最近在 A 国蔓延,为了尽快控制病毒,A 国准备给大量民众进病毒检测.然而,用于检测的试剂盒紧缺.为了解决这 ...

  • Python|二叉树叶子结点问题解决方法

    问题描述键盘输入一颗二叉树,求解其叶子结点个数.示例: 输入:4,2,6,1,3,5输出:3解决方案一棵树当中没有子结点(即度为0)的结点称为叶子结点,简称"叶子".当二叉树为空时 ...

  • 批量合并多个Excel工作簿文件到一起其实很简单

    批量合并多个Excel工作簿文件到一起其实很简单

  • Python|二叉树的遍历问题解决方法

    问题描述二叉树是由n个结点的有限集合,该集合或者为空集,或者由一个根节点和两颗互不相交的.分别称为根节点的左子树和右子树的二叉树组成.二叉树特征:每个结点最多只有两颗子树,即二叉树中结点的度最高不能超 ...

  • 史上多表合并最简单的方法

    源文件有多个月份的销售报表,现在要把多个月份的表汇总,以6个月的为例. 图 1 操作步骤如下: Step1:点击菜单数据→新建查询→从文件→从工作簿,找到当前文件的位置并导入: 图 2 图 3 Ste ...

  • 用Python执行SQL、Excel常见任务?10个方法全搞定!

    数据从业者有许多工具可用于分割数据.有些人使用 Excel,有些人使用SQL,有些人使用Python.对于某些任务,使用 Python 的优点是显而易见的.以更快的速度处理更大的数据集.使用基于 Py ...

  • 使用PS软件场景模糊制作浅景深 突出主体的好方法

    大家好,今天为大家带来一节利用场景模糊制作浅景深的方法,这种浅景深,能够增加虚实对比,使主体更加突出. 本节中要聊一下简单的抠图,还有一些新技能的讲解,请大家留心学习.好了,开始我们今天的内容吧. 先 ...