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

 更新时间:2022年05月18日 16:24:10   作者:​ Python研究者   ​  
这篇文章主要介绍了Python在不同场景合并多个Excel的方法,文章围绕主题总共分享了三种方法,具有一定的参考价值,需要的小伙伴可以参考一下

前言

三种场景

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

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

01 合并多个同字段的excel

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

1.xlsx

1.xlsx

1.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 = 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  **中,其结果如下:

02 拼接多个不同字段的excel

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

1.xlsx

2.xlsx

3.xlsx

将这三个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  **中,其结果如下:

03 合并一个excel的多个sheet

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

sheet1

sheet2

sheet3

将同一个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的方法的文章就介绍到这了,更多相关合并Excel方法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python制作基础学生信息管理系统

    Python制作基础学生信息管理系统

    本文详细讲解了Python制作基础学生信息管理系统的实现,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-12-12
  • pytorch训练时的显存占用递增的问题解决

    pytorch训练时的显存占用递增的问题解决

    本文主要介绍了pytorch训练时的显存占用递增的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • Python字符串的一些操作方法总结

    Python字符串的一些操作方法总结

    在本文里小编给大家整理了关于Python字符串的一些操作方法和相关要点总结,有需要的朋友们可以学习下。
    2019-06-06
  • 如何将python的数据存储到mysql数据库中

    如何将python的数据存储到mysql数据库中

    在很多数据处理项目中,将数据存储到数据库中是非常常见的操作,下面这篇文章主要给大家介绍了关于如何将python的数据存储到mysql数据库中的相关资料,需要的朋友可以参考下
    2023-12-12
  • pandas merge报错的解决方案

    pandas merge报错的解决方案

    这篇文章主要介绍了pandas merge报错的解决方案,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-04-04
  • 使用pyinstaller打包PyQt4程序遇到的问题及解决方法

    使用pyinstaller打包PyQt4程序遇到的问题及解决方法

    今天小编就为大家分享一篇使用pyinstaller打包PyQt4程序遇到的问题及解决方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-06-06
  • Python脚本启动应用并输入账号或密码的操作命令

    Python脚本启动应用并输入账号或密码的操作命令

    这篇文章主要介绍了Python脚本启动应用并输入账号或密码,安装所需要的模块pyautogui、subprocess、psutil等,可以通过pip安装,下面以安装pyautogui为例cmd命令行中输入,需要的朋友可以参考下
    2024-05-05
  • 在django项目中,如何单独运行某个python文件

    在django项目中,如何单独运行某个python文件

    这篇文章主要介绍了在django项目中单独运行某个python文件的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-04-04
  • 分享8 个常用pandas的 index设置

    分享8 个常用pandas的 index设置

    这篇文章主要介绍了分享8 个常用pandas的 index设置,pandas 中的 index 是行索引或行标签。行标签可以说是 pandas 的灵魂一签,支撑了 pandas 很多强大的业务功能,比如多个数据框的 join, merge 操作,自动对齐等,下面来看看文章得具体介绍吧
    2021-12-12
  • wxpython 学习笔记 第一天

    wxpython 学习笔记 第一天

    学习wxpython的朋友,可以看下,了解下wxpython
    2009-03-03

最新评论