iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >如何用python合并多个excel文件
  • 528
分享到

如何用python合并多个excel文件

2024-04-02 19:04:59 528人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

目录安装模块 XlsxWriter 示例 合并excel数据 表头都一样的 excel 表头都不一样的 excel 表头都不一样的 excel 安装模块 1、找到对应的模块 &nb

安装模块

1、找到对应的模块  Http://www.python-excel.org/

2、用 pip install 安装


pip3 install xlrd
pip3 install XlsxWriter

因为使用的是 python3,所以安装的时候采用 pip3。

XlsxWriter 示例

先看看简单的演示:


import xlsxwriter

# 创建一个工作簿并添加一个工作表
workbook = xlsxwriter.Workbook("c.xlsx")
worksheet = workbook.add_worksheet()

# 设置列宽
worksheet.set_column("A:A", 20)

# 设置格式
bold = workbook.add_fORMat({"bold": True})

# 设置单元格的值
worksheet.write("A1", "Hello")

# 带格式的单元格
worksheet.write("A2", "World")

# 写一些数字,用行列标识
worksheet.write(2, 0, 123)
worksheet.write(3, 0, 123.456, bold)

# 插入一张图片
worksheet.insert_image("B5", "s.png")

# 关闭文件流
workbook.close()

运行结果如下:

合并Excel数据

对于合并 excel,有两种 case ,一种是表头都是一样的,一种是表头不一样的excel ,但是希望放到同一个表格里面,方便查看

表头都一样的 excel

这个处理很简单,具体代码如下:


import xlrd
import xlsxwriter

source_xls = ["a.xlsx", "b.xlsx"]
target_xls = "3.xlsx"

# 读取数据
data = []
for i in c:
 wb = xlrd.open_workbook(i)
 for sheet in wb.sheets():
  for rownum in range(sheet.nrows):
   data.append(sheet.row_values(rownum))
print(data)
# 写入数据
workbook = xlsxwriter.Workbook(target_xls)
worksheet = workbook.add_worksheet()
font = workbook.add_format({"font_size": 14})
for i in range(len(data)):
 for j in range(len(data[i])):
  worksheet.write(i, j, data[i][j], font)
# 关闭文件流
workbook.close()

Excel 是由行和列组成的,所以这里将所有文件中的所有 sheet 中的数据读取出来组成一个二维数组,然后再写入新的 Excel。

表头都不一样的 excel

对于表头不一样的 excel,可能需要手动选取表格的一部分,然后进行合并。具体代码如下:


import xlrd
import xlsxwriter

source_xls = ["a.xlsx", "b.xlsx"]
target_xls = "合并.xlsx"

# 读取数据
data = []
# 重复数据
dupdata = []
# 姓名列表,按照姓名去重
name = []
# 获取excel的个数
sheetcount = len(source_xls)
i = 0
while i < len(source_xls):
 wb = xlrd.open_workbook(source_xls[i])
 # 存储不同excel 的数据
 data.append([])
 # 一个excel 可能存在多张表格
 for sheet in wb.sheets():
  if i == 0:
   # 先把表头添加进去
   dupdata.append(sheet.row_values(0))
  for rownum in range(sheet.nrows):
   # 判断名字是否重复,表头都是姓名开头的,所以把姓名除去
   if (sheet.row_values(rownum)[0] in name):
    dupdata.append(sheet.row_values(rownum))
    # 给数据添加另一个表的表头
    if (sheet.row_values(rownum)[0] == '姓名'):
     data[i].append(sheet.row_values(rownum))
   else:
    name.append(sheet.row_values(rownum)[0])
    data[i].append(sheet.row_values(rownum))
 i+=1

# 合并数据
workbook = xlsxwriter.Workbook(target_xls)
worksheet = workbook.add_worksheet()
font = workbook.add_format({"font_size": 14})
lineNum = 0
for num in range(len(data)):
 # 区分来自不同excel 的数据
 if num== 0 :
  for i in range(len(data[num])):
   # 姓名
   worksheet.write(lineNum, 0, data[num][i][0], font)
   # 检查编号
   worksheet.write(lineNum, 1, data[num][i][1], font)
   # 年龄
   worksheet.write(lineNum, 2, data[num][i][23], font)
   # 蓝标
   worksheet.write(lineNum, 3, data[num][i][14], font)
   # 黄标
   worksheet.write(lineNum, 4, data[num][i][19], font)
   worksheet.write(lineNum, 5, data[num][i][20], font)
   worksheet.write(lineNum, 6, data[num][i][21], font)
   # 大小
   worksheet.write(lineNum, 7, data[num][i][24], font)
   worksheet.write(lineNum, 8, data[num][i][25], font)
   worksheet.write(lineNum, 9, data[num][i][26], font)
  
   lineNum += 1
 # 只有两个excel ,所以直接用了 else 
 else:
  for i in range(len(data[num])):
   lineNum += 1
   # 姓名
   worksheet.write(lineNum, 0, data[num][i][0], font)
   # 检查编号
   worksheet.write(lineNum, 1, data[num][i][1], font)
   # 年龄
   worksheet.write(lineNum, 2, data[num][i][2], font)
   # 蓝标
   worksheet.write(lineNum, 3, data[num][i][30], font)
# 关闭文件流
workbook.close()

# 针对重复数据,连表头一起输出,方便后续回顾查看
workbook = xlsxwriter.Workbook("重复.xlsx")
worksheet = workbook.add_worksheet()
font = workbook.add_format({"font_size": 14})
for i in range(len(dupdata)):
 for j in range(len(dupdata[i])):
  worksheet.write(i, j, dupdata[i][j], font)
# 关闭文件流
workbook.close()

Excel 是由行和列组成的,所以这里将所有文件中的所有 sheet 中的数据读取出来组成一个二维数组,然后再写入新的 Excel。

表头都不一样的 excel

对于表头不一样的 excel,可能需要手动选取表格的一部分,然后进行合并。具体代码如下:


import xlrd
import xlsxwriter

source_xls = ["a.xlsx", "b.xlsx"]
target_xls = "合并.xlsx"

# 读取数据
data = []
# 重复数据
dupdata = []
# 姓名列表,按照姓名去重
name = []
# 获取excel的个数
sheetcount = len(source_xls)
i = 0
while i < len(source_xls):
 wb = xlrd.open_workbook(source_xls[i])
 # 存储不同excel 的数据
 data.append([])
 # 一个excel 可能存在多张表格
 for sheet in wb.sheets():
  if i == 0:
   # 先把表头添加进去
   dupdata.append(sheet.row_values(0))
  for rownum in range(sheet.nrows):
   # 判断名字是否重复,表头都是姓名开头的,所以把姓名除去
   if (sheet.row_values(rownum)[0] in name):
    dupdata.append(sheet.row_values(rownum))
    # 给数据添加另一个表的表头
    if (sheet.row_values(rownum)[0] == '姓名'):
     data[i].append(sheet.row_values(rownum))
   else:
    name.append(sheet.row_values(rownum)[0])
    data[i].append(sheet.row_values(rownum))
 i+=1

# 合并数据
workbook = xlsxwriter.Workbook(target_xls)
worksheet = workbook.add_worksheet()
font = workbook.add_format({"font_size": 14})
lineNum = 0
for num in range(len(data)):
 # 区分来自不同excel 的数据
 if num== 0 :
  for i in range(len(data[num])):
   # 姓名
   worksheet.write(lineNum, 0, data[num][i][0], font)
   # 检查编号
   worksheet.write(lineNum, 1, data[num][i][1], font)
   # 年龄
   worksheet.write(lineNum, 2, data[num][i][23], font)
   # 蓝标
   worksheet.write(lineNum, 3, data[num][i][14], font)
   # 黄标
   worksheet.write(lineNum, 4, data[num][i][19], font)
   worksheet.write(lineNum, 5, data[num][i][20], font)
   worksheet.write(lineNum, 6, data[num][i][21], font)
   # 大小
   worksheet.write(lineNum, 7, data[num][i][24], font)
   worksheet.write(lineNum, 8, data[num][i][25], font)
   worksheet.write(lineNum, 9, data[num][i][26], font)
  
   lineNum += 1
 # 只有两个excel ,所以直接用了 else 
 else:
  for i in range(len(data[num])):
   lineNum += 1
   # 姓名
   worksheet.write(lineNum, 0, data[num][i][0], font)
   # 检查编号
   worksheet.write(lineNum, 1, data[num][i][1], font)
   # 年龄
   worksheet.write(lineNum, 2, data[num][i][2], font)
   # 蓝标
   worksheet.write(lineNum, 3, data[num][i][30], font)
# 关闭文件流
workbook.close()

# 针对重复数据,连表头一起输出,方便后续回顾查看
workbook = xlsxwriter.Workbook("重复.xlsx")
worksheet = workbook.add_worksheet()
font = workbook.add_format({"font_size": 14})
for i in range(len(dupdata)):
 for j in range(len(dupdata[i])):
  worksheet.write(i, j, dupdata[i][j], font)
# 关闭文件流
workbook.close()

合并后的结果

重复列表结果如下:

以上就是如何用Python合并多个excel文件的详细内容,更多关于python 合并excel文件的资料请关注编程网其它相关文章!

--结束END--

本文标题: 如何用python合并多个excel文件

本文链接: https://www.lsjlt.com/news/121616.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何用python合并多个excel文件
    目录安装模块 XlsxWriter 示例 合并Excel数据 表头都一样的 excel 表头都不一样的 excel 表头都不一样的 excel 安装模块 1、找到对应的模块 &nb...
    99+
    2024-04-02
  • vbs如何合并多个excel文件
    这篇文章将为大家详细讲解有关vbs如何合并多个excel文件,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。代码如下:Const xlWorkbookNormal = -4143 Const xlSaveC...
    99+
    2023-06-08
  • 怎么用python合并多个excel文件
    本篇内容主要讲解“怎么用python合并多个excel文件”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用python合并多个excel文件”吧!python可以做什么Python是一种编程...
    99+
    2023-06-14
  • 怎么用Python代码合并多个Excel文件
    这篇文章主要介绍“怎么用Python代码合并多个Excel文件”,在日常操作中,相信很多人在怎么用Python代码合并多个Excel文件问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用Python代码合并...
    99+
    2023-06-16
  • python——对多个Excel文件的多个sheet表分别合并
            工作中遇到需要合并多个sheet表的逐月数据的excel文件。即对多月数据,依据sheet表进行合并,最终形成年度数据。(该方法不要求文件名有规律,也不要求sheet表名称有规律) 如:文件结构     以下为处理方法: ...
    99+
    2023-09-23
    python excel
  • 多个 EXCEL文件怎么合并成一个文件
    今天就跟大家聊聊有关多个 EXCEL文件怎么合并成一个文件,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。同一文件夹里有多个格式相同的EXCEL文件,需要把它们合并到一个EXCEL文件...
    99+
    2023-06-03
  • python如何用nbmerge合并多个notebook文件
    这篇文章主要讲解了“python如何用nbmerge合并多个notebook文件”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“python如何用nbmerge合并多个notebook文件”吧...
    99+
    2023-06-19
  • python如何按列合并多个文件
    使用python按列合并多个文件的方法:1.新建python项目;2.导入pandas模块;3.使用pd.read方法分别打开文件;4.使用pd.merge()方法按列合并文件;具体步骤如下:首先,打开python,并新建一个python项...
    99+
    2024-04-02
  • Python 批量合并多个txt文件
    # -*- coding:utf-8 -*- #os模块中包含很多操作文件和目录的函数 import os #获取目标文件夹的路径 meragefiledir = os.getcwd()+'\\MerageFiles...
    99+
    2023-01-31
    多个 批量 文件
  • python合并多个excel的详细过程
    目录前言代码编写1.导包2.定义位置和表头3.获取要合并的所有exce表格4.打开Exce文件5.获取exce文件下的所有sheet6.获取sheet下有多少行数据7.获取sheet...
    99+
    2024-04-02
  • 如何用python合并多个有规则命名的nc文件
    现有多个nc文件,命名除了年份不同外,其他皆相同。希望将多个的nc文件合并为一个。 其中,每个nc文件内包含如下内容,包含12个月均数据 因此,我们可以知道,合并两个nc文件,t...
    99+
    2024-04-02
  • 怎么用vbscript合并多个文本文件
    这篇文章主要介绍“怎么用vbscript合并多个文本文件”,在日常操作中,相信很多人在怎么用vbscript合并多个文本文件问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用vbscript合并多个文本文件...
    99+
    2023-06-08
  • Python怎么实现Excel文件的合并
    本文小编为大家详细介绍“Python怎么实现Excel文件的合并”,内容详细,步骤清晰,细节处理妥当,希望这篇“Python怎么实现Excel文件的合并”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、单目录下面...
    99+
    2023-06-29
  • 怎样将多个html文件合并一个文件
    这篇文章主要介绍怎样将多个html文件合并一个文件,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!将多个html文件合并一个文件的方法:首先新建一个【X.html】文件;然后在【X.html】主题循环加入iframe标...
    99+
    2023-06-06
  • 教你用Python代码实现合并excel文件
    目录一、安装模块二、XlsxWriter 示例三、合并Excel数据四、表头都一样的 excel五、表头都不一样的 excel六、合并后的结果一、安装模块 1、找到对应的模块 htt...
    99+
    2024-04-02
  • python 按照sheet合并多个Excel的示例代码(多个sheet)
    工作中会遇到这样的需求,有多个Excel的格式一样,都有多个sheet,且每个sheet的名字和格式一样,我们需要按照sheet 合并,就是说合并后的表的格式和合并钱的格式是一样的。...
    99+
    2024-04-02
  • 如何使用DOS命令合并多个文本文件的内容
    这篇文章将为大家详细讲解有关如何使用DOS命令合并多个文本文件的内容,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。(1)首先,使用本书中“批量按序更改文件名”介绍的方法对这100多个文本文件进行按序号重命...
    99+
    2023-06-08
  • Python在不同场景合并多个Excel的方法
    目录前言01 合并多个同字段的excel02 拼接多个不同字段的excel03 合并一个excel的多个sheet前言 三种场景: 多个同字段的excel文件合并成一个excel多个...
    99+
    2024-04-02
  • pdf文件如何合并成一个
    这篇文章主要介绍“pdf文件如何合并成一个”,在日常操作中,相信很多人在pdf文件如何合并成一个问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”pdf文件如何合并成一个”的疑惑有所帮助!接下来,请跟着小编一起来...
    99+
    2023-07-02
  • 如何在 Java 中将多个 PDF 文件合并为一个 PDF
    如果您正在开发涉及处理 PDF 文件的 Java 项目,则可能需要将多个 PDF 文件合并到一个文档中。在本文中,我们将演示如何使用 Java 编程语言来实现这一目标。我们将从以下两个方面向您展示如何将多个PDF文件合并为一个PDF: 将文...
    99+
    2023-08-18
    java pdf python
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作