使用Pandas合并excel文件(使用pandas合并多个excel)
liuian 2025-05-02 11:48 53 浏览
有一个这样的需求,有很多数据格式相同的excel文件分散在不同的目录,需要把它们的数据合到一个excel文件中,excel文件不多的情况下也许可以手工整理,假如有成百上千和文件要合并,手工合并将是很麻烦的事情,可以使用python语言的第三方库pandas来轻松解决这个问题。
先来梳理下实现的思路:
- 首先,遍历整个目录及子目录,识别出需要合并的excel文件,添加到合并文件列表。
- 接下来,使用pandas的read_excel方法读取所有的excel,将读取的数据对象添加到列表中。
- 最后,使用pandas的concat方法将pandas读取的excel数据对象列表合并,使用to_excel方法生成新的excel文件。
遍历文件
├─示例文件夹01
│ │ data_001.xlsx
│ │
│ └─文件夹001
│ data_002.xlsx
│
└─示例文件夹02
data_003.xlsx本次示例文件目录结构如上所示,需要合并的excel文件名拥有"data_"前缀,可以使用os.walk方法遍历目录及子目录下的文件,我们在交互式命令中演示os.walk方法返回的结果。
>>> import os
>>> paths = os.walk("./")
>>> for item in paths:
... print(item)
...
('./', ['示例文件夹01', '示例文件夹02'], [])
('./示例文件夹01', ['文件夹001'], ['data_001.xlsx'])
('./示例文件夹01\\文件夹001', [], ['data_002.xlsx'])
('./示例文件夹02', [], ['data_003.xlsx'])os.walk方法返回要遍历的目录及其子目录下的所有文件,它返回的是一个三元组(root, dirs, files),root表示的是当前正在遍历的文件夹,dirs是一个列表,内容是该文件夹下的目录(不包括子目录),files是一个列表,内容是root所表示的文件夹下的文件。那么,当找到files中一个匹配的excel文件,该文件的完整路径就可以通过root+file名拼接得到。
Pandas上手
pandas不是python标准库,需要使用pip install pandas进行安装,如果操作excel还需要安装openpyxl库,即pip install openpyxldata_001.xlsx:
name age
a 11
b 12
data_002.xlsx:
name age
c 13
d 14
data_003.xlsx:
name age
e 15
f 16本次示例中各excel文件的内容如上所示,虽然本文不会使用pandas的很多功能,这里还是在交互式命令中演示一些pandas的基本操作。另外,Pandas是非常强大的数据分析工具,其功能远远不止这里提到的一些皮毛,值得深入学习掌握。
>>> import pandas as pd
# DataFrame是一种表格型的数据结构,类似于二维数组
>>> df = pd.DataFrame([["a",11],["b",12]],columns=["名字","年龄"])
>>> df
名字 年龄
0 a 11
1 b 12
# 过滤名字为a的行
>>> df[df["名字"]=="a"]
名字 年龄
0 a 11
# 过滤年龄为12的行
>>> df[df["年龄"]==12]
名字 年龄
1 b 12
# 筛选名字这一列数据
>>> df["名字"]
0 a
1 b
Name: 名字, dtype: object
# 取单元格0行、1列的数据
>>> df.iloc[0,1]
11
# 取单元格1行、0列的数据
>>> df.iloc[1,0]
'b'
# 将数据输出为excel文件
>>> df.to_excel("excel_demo.xlsx")上面to_excel方法生成excel文件内容如下图所示
合并excel文件
有了上面的基础,就可以开始实现合并excel文件的脚本了,参考代码如下
import os
import pandas as pd
# 合并当前目录及子目录下前缀为data_的excel文件
def mergeExcel(prefix="data_"):
# 遍历当前目录及子目录
paths = os.walk("./")
excel_list = []
for root, dirs, files in paths:
for file_name in files:
if file_name.startswith(prefix):
# 将满足data_前缀的excel文件路径+文件名添加到excel_list列表
excel_list.append(os.path.join(root, file_name))
dataframe_lst = []
print("开始合并excel文件...")
# 遍历每一个符合要求的excel文件
for excel_file in excel_list:
# pandas读取excel内容,并添加到dafaframe_lst列表
dataframe_lst.append(pd.read_excel(excel_file))
# 将dataframe_lst中的excel数据合并为一个DataFrame数据结构
dataframe_merged = pd.concat(dataframe_lst)
# 将合并的DataFrame生成新的excel文件
dataframe_merged.to_excel("合并文件.xlsx", index=False)
if __name__ == "__main__":
mergeExcel()合并后的文件内容如下
更进一步,显示进度条
上面的脚本已经满足了最初的需求,但是在执行脚本的过程中看不到任何反馈,不知道什么时候脚本会执行结束,接下来为脚本添加进度条显示。可以使用使用tqdm包,执行命令pip install tqdm进行安装,tqdm包非常容易使用,增加了进度条的脚本执行结果显示如下,它是动态显示进度的,这里只是展示最终的结果。
> python .\merge.py
开始合并excel文件...
100%|██████████████████████████████████████████████████████████████████████████████████████████████████████████| 3/3 [00:00<00:00, 3.24it/s]下面是增加了进度条功能的代码,可以发现除了导入tdqm的语句之外,只有一行代码与之前不同,使用tqdm非常简单,只需要将需要展示进度的任意可迭代的对象传给tqdm方法即可。
import os
import pandas as pd
from tqdm import tqdm
# 合并当前目录及子目录下前缀为data_的excel文件
def mergeExcel(prefix="data_"):
# 遍历当前目录及子目录
paths = os.walk("./")
excel_list = []
for root, dirs, files in paths:
for file_name in files:
if file_name.startswith(prefix):
# 将满足data_前缀的excel文件路径+文件名添加到excel_list列表
excel_list.append(os.path.join(root, file_name))
dataframe_lst = []
print("开始合并excel文件...")
# 遍历每一个符合要求的excel文件
for excel_file in tqdm(excel_list):
# pandas读取excel内容,并添加到dafaframe_lst列表
dataframe_lst.append(pd.read_excel(excel_file))
# 将dataframe_lst中的excel数据合并为一个DataFrame数据结构
dataframe_merged = pd.concat(dataframe_lst)
# 将合并的DataFrame生成新的excel文件
dataframe_merged.to_excel("合并文件.xlsx", index=False)
if __name__ == "__main__":
mergeExcel()
参考文献
[1]. 《流畅的python》17.5 显示下载进度并处理错误,第429页;
相关推荐
-
- 驱动网卡(怎么从新驱动网卡)
-
网卡一般是指为电脑主机提供有线无线网络功能的适配器。而网卡驱动指的就是电脑连接识别这些网卡型号的桥梁。网卡只有打上了网卡驱动才能正常使用。并不是说所有的网卡一插到电脑上面就能进行数据传输了,他都需要里面芯片组的驱动文件才能支持他进行数据传输...
-
2026-01-30 00:37 liuian
- win10更新助手装系统(微软win10更新助手)
-
1、点击首页“系统升级”的按钮,给出弹框,告诉用户需要上传IMEI码才能使用升级服务。同时给出同意和取消按钮。华为手机助手2、点击同意,则进入到“系统升级”功能华为手机助手华为手机助手3、在检测界面,...
- windows11专业版密钥最新(windows11专业版激活码永久)
-
Windows11专业版的正版密钥,我们是对windows的激活所必备的工具。该密钥我们可以通过微软商城或者通过计算机的硬件供应商去购买获得。获得了windows11专业版的正版密钥后,我...
-
- 手机删过的软件恢复(手机删除过的软件怎么恢复)
-
操作步骤:1、首先,我们需要先打开手机。然后在许多图标中找到带有[文件管理]文本的图标,然后单击“文件管理”进入页面。2、进入页面后,我们将在顶部看到一行文本:手机,最新信息,文档,视频,图片,音乐,收藏,最后是我们正在寻找的[更多],单击...
-
2026-01-29 23:55 liuian
- 一键ghost手动备份系统步骤(一键ghost 备份)
-
步骤1、首先把装有一键GHOST装系统的U盘插在电脑上,然后打开电脑马上按F2或DEL键入BIOS界面,然后就选择BOOT打USDHDD模式选择好,然后按F10键保存,电脑就会马上重启。 步骤...
- 怎么创建局域网(怎么创建局域网打游戏)
-
1、购买路由器一台。进入路由器把dhcp功能打开 2、购买一台交换机。从路由器lan端口拉出一条网线查到交换机的任意一个端口上。 3、两台以上电脑。从交换机任意端口拉出网线插到电脑上(电脑设置...
- 精灵驱动器官方下载(精灵驱动手机版下载)
-
是的。驱动精灵是一款集驱动管理和硬件检测于一体的、专业级的驱动管理和维护工具。驱动精灵为用户提供驱动备份、恢复、安装、删除、在线更新等实用功能。1、全新驱动精灵2012引擎,大幅提升硬件和驱动辨识能力...
- 一键还原系统步骤(一键还原系统有哪些)
-
1、首先需要下载安装一下Windows一键还原程序,在安装程序窗口中,点击“下一步”,弹出“用户许可协议”窗口,选择“我同意该许可协议的条款”,并点击“下一步”。 2、在弹出的“准备安装”窗口中,可...
- 电脑加速器哪个好(电脑加速器哪款好)
-
我认为pp加速器最好用,飞速土豆太懒,急速酷六根本不工作。pp加速器什么网页都加速,太任劳任怨了!以上是个人观点,具体性能请自己试。ps:我家电脑性能很好。迅游加速盒子是可以加速电脑的。因为有过之...
- 任何u盘都可以做启动盘吗(u盘必须做成启动盘才能装系统吗)
-
是的,需要注意,U盘的大小要在4G以上,最好是8G以上,因为启动盘里面需要装系统,内存小的话,不能用来安装系统。内存卡或者U盘或者移动硬盘都可以用来做启动盘安装系统。普通的U盘就可以,不过最好U盘...
- u盘怎么恢复文件(u盘文件恢复的方法)
-
开360安全卫士,点击上面的“功能大全”。点击文件恢复然后点击“数据”下的“文件恢复”功能。选择驱动接着选择需要恢复的驱动,选择接入的U盘。点击开始扫描选好就点击中间的“开始扫描”,开始扫描U盘数据。...
- 系统虚拟内存太低怎么办(系统虚拟内存占用过高什么原因)
-
1.检查系统虚拟内存使用情况,如果发现有大量的空闲内存,可以尝试释放一些不必要的进程,以释放内存空间。2.如果系统虚拟内存使用率较高,可以尝试增加系统虚拟内存的大小,以便更多的应用程序可以使用更多...
-
- 剪贴板权限设置方法(剪贴板访问权限)
-
1、首先打开iphone手机,触碰并按住单词或图像直到显示选择选项。2、其次,然后选取“拷贝”或“剪贴板”。3、勾选需要的“权限”,最后选择开启,即可完成苹果剪贴板权限设置。仅参考1.打开苹果手机设置按钮,点击【通用】。2.点击【键盘】,再...
-
2026-01-29 21:37 liuian
- 平板系统重装大师(平板重装win系统)
-
如果你的平板开不了机,但可以连接上电脑,那就能好办,楼主下载安装个平板刷机王到你的个人电脑上,然后连接你的平板,平板刷机王会自动识别你的平板,平板刷机王上有你平板的我刷机包,楼主点击下载一个,下载完成...
- 联想官网售后服务网点(联想官网售后服务热线)
-
联想3c服务中心是联想旗下的官方售后,是基于互联网O2O模式开发的全新服务平台。可以为终端用户提供多品牌手机、电脑以及其他3C类产品的维修、保养和保险服务。根据客户需求层次,联想服务针对个人及家庭客户...
- 一周热门
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)
