Python 批量合并csv文件
一、批量合并csv文件《方法1》
import pandas as pd
import glob
import os # 获取所有CSV文件的路径
file_paths = glob.glob("C:\\Users\\Admin\\Desktop\\数据核对\\*.csv")
# 使用glob.glob函数获取指定目录下所有以.csv为扩展名的文件路径,并将结果存储在file_paths列表中 print(file_paths) # 打印出这些文件路径供你检查 # 创建一个空的 DataFrame
df = pd.DataFrame()
# 创建一个空的DataFrame,用于存储合并后的数据 # 逐个读取每个CSV文件,并将其添加到DataFrame中
for file_path in file_paths:
# 读取CSV文件并添加文件名为一列
temp_df = pd.read_csv(file_path, encoding='gbk')
# 使用pd.read_csv函数读取CSV文件,encoding参数指定了文件的编码格式,这里使用GBK编码
file_name = os.path.basename(file_path)
print(file_name)
# 使用os.path.basename函数获取文件名(包含扩展名)
temp_df['file_name'] = file_name
# 将文件名作为新的一列添加到temp_df中
df = df.append(temp_df, ignore_index=True)
# 使用df.append函数将temp_df合并到主DataFrame df中,ignore_index=True表示重新设置行索引 # 将DataFrame写入新的CSV文件中
df.to_csv("C:\\Users\\Admin\\Desktop\\合并数据.csv", index=False)
# 使用df.to_csv函数将合并后的数据保存为新的CSV文件,index=False表示不保存行索引
二、批量合并csv文件 多文件编码格式《方法2》
import pandas as pd
import glob
import os # 使用glob.glob函数获取指定目录下所有以.csv为扩展名的文件路径,并将结果存储在file_paths列表中
file_paths = glob.glob("C:\\Users\\Admin\\Desktop\\数据核对\\*.csv") # 创建一个空的DataFrame,用于存储合并后的数据
df = pd.DataFrame() # 循环遍历每个CSV文件,并将其添加到DataFrame中
for file_path in file_paths:
# 尝试使用不同的编码格式读取CSV文件,直到成功为止
for encoding in ['utf-8', 'gbk', 'gb2312', 'utf-16', 'iso-8859-1']:
try:
# 使用pd.read_csv函数读取CSV文件,encoding参数指定了文件的编码格式
temp_df = pd.read_csv(file_path, encoding=encoding)
break # 如果成功读取,则跳出循环
except UnicodeDecodeError: # 如果出现编码错误,则捕获该错误,并继续尝试下一个编码格式
continue
else: # 如果没有任何编码格式成功读取CSV文件,则打印一条错误消息,并继续处理下一个文件
print(f"无法读取CSV文件:{file_path}")
continue # 使用os.path.basename函数获取文件名(包含扩展名)
file_name = os.path.basename(file_path) # 将文件名作为新的一列添加到DataFrame中
temp_df['file_name'] = file_name # 使用df.append函数将temp_df合并到主DataFrame df中,ignore_index=True表示重新设置行索引
df = df.append(temp_df, ignore_index=True) # 使用df.to_csv函数将合并后的数据保存为新的CSV文件,index=False表示不保存行索引
df.to_csv("C:\\Users\\Admin\\Desktop\\合并数据.csv", index=False)
三、批量合并csv文件《方法3》
import os
import pandas as pd # 指定包含CSV文件的文件夹路径
folder_path = "C:\\Users\\Admin\\Desktop\\数据核对" # 获取文件夹中的所有CSV文件
csv_files = [file for file in os.listdir(folder_path) if file.endswith('.csv')] print(csv_files) # 打印出找到的CSV文件列表 # 创建一个空的DataFrame来存储合并后的数据
merged_data = pd.DataFrame() # 遍历所有CSV文件并合并它们
for file in csv_files:
file_path = os.path.join(folder_path, file) # 读取CSV文件,使用GBK编码(GBK是一种常见的中文字符编码)
df = pd.read_csv(file_path, encoding='GBK') # 添加一个新的列,用于标识数据来自哪个CSV文件
df['SourceFile'] = file # 合并数据,将当前CSV文件的数据追加到已合并的数据中
merged_data = merged_data.append(df, ignore_index=True) # 将合并后的数据保存为一个新的CSV文件,指定index=False以避免保存索引列
merged_data.to_csv("C:\\Users\\Admin\\Desktop\\合并数据.csv", index=False) # 打印完成消息
print('CSV文件合并完成并保存为合并数据.csv')
四、合并多种不同编码格式的csv文件
import os
import pandas as pd
import chardet def merge_csv_files(folder_path,output_path):
# 获取文件夹中的所有CSV文件
csv_files = [file for file in os.listdir(folder_path) if file.endswith('.csv')]
print(csv_files)
# 创建一个空的DataFrame来存储合并后的数据
merged_data = pd.DataFrame() # 遍历所有CSV文件并合并它们
for file in csv_files:
file_path = os.path.join(folder_path, file) # 使用 chardet.detect 函数检测文件编码格式
with open(file_path, 'rb') as f:
result = chardet.detect(f.read())
encoding = result['encoding'] # 读取CSV文件,指定检测到的编码格式
df = pd.read_csv(file_path, encoding=encoding) if "YYFX_OrderList" in file_path:
df.insert(12, 'NewColumnName', df.iloc[:, 11])
# 添加一个新的列,用于标识数据来自哪个CSV文件
df['SourceFile'] = file # 合并数据,将当前CSV文件的数据追加到已合并的数据中
merged_data = merged_data.append(df, ignore_index=True) # 将合并后的数据保存为一个新的CSV文件,指定index=False以避免保存索引列
merged_data.to_csv(output_path, index=False)
print("已将所有CSV文件合并为一个文件:合并数据.csv") folder_path = "C:\\Users\\Admin\\Desktop\\数据核对"
output_path = "C:\\Users\\Admin\\Desktop\\数据核对\\数据汇总.csv"
merge_csv_files(folder_path,output_path)
Python 批量合并csv文件的更多相关文章
- 使用Python批量合并PDF文件(带书签功能)
网上找了几个合并pdf的软件,发现不是很好用,一般都没有添加书签的功能. 又去找了下python合并pdf的脚本,发现也没有添加书签的功能的. 于是自己动手编写了一个小工具,使用了PyPDF2. 下面 ...
- Python批量处理CSV文件
#encoding: utf-8 __author__ = 'DELL' import csv import glob import datetime import sys import os rel ...
- Python批量合并处理B站视频
最近想学习后端,又不想花钱,怎么办呢?于是在手机端B站(哔哩哔哩)上面找到了满意的免费视频教程,但是手机端看起来很不方便啊.于是,我通过在手机端缓存下来后,导入到了电脑端,但是我后面了发现两个问题: ...
- python在处理CSV文件时,字符串和列表写入的区别
概述 Python在处理CSV文件时,如果writerow的对象是<type 'unicode'>字符串时,写入到CSV文件时将会出现一个字符占一个单元格的情况: 但是将字符串转换为列表类 ...
- 使用ffmpeg批量合并flv文件
title: 使用ffmpeg批量合并flv文件 toc: false date: 2018-10-14 16:08:19 categories: methods tags: ffmpeg flv 使 ...
- python批量处理压缩文件
python批量处理压缩文件 博客小序:在数据的处理中,下载的数据很有可能是许多个压缩文件,自己一个一个解压较为麻烦,最近几日自己在处理一次下载的数据时,遇到大量的压缩数据需要处理,于是利用pytho ...
- python批量运行py文件
import os path="E:\\python" #批量的py文件路径 for root,dirs,files in os.walk(path): #进入文件夹目录 for ...
- python中操作csv文件
python中操作csv文件 读取csv improt csv f = csv.reader(open("文件路径","r")) for i in f: pri ...
- Python:使用pymssql批量插入csv文件到数据库测试
并行进程怎么使用? import os import sys import time def processFunc(i): time.sleep(10-i) print i if __name__= ...
- python脚本-excel批量转换为csv文件
pandas和SQL数据分析实战视频教程 https://study.163.com/course/courseMain.htm?courseId=1006383008&share=2& ...
随机推荐
- CF131D Subway 题解
题目传送门 前置知识 强连通分量 | 最短路 解法 考虑用 Tarjan 进行缩点,然后跑最短路. 缩点:本题的缩点有些特殊,基于有向图缩点修改而得,因为是无向图,所以在 Tarjan 过程中要额外记 ...
- NEMU PA 2-2 实验报告
课程地址:https://www.bilibili.com/video/BV1f7411D7P6 一.实验目的 在PA2-1中,我们实现了了解了程序的装载和对指令的解码和执行,在这一章节我们将继续深入 ...
- 49从零开始用Rust编写nginx,我竟然在同一个端口上绑定了多少IP
wmproxy wmproxy已用Rust实现http/https代理, socks5代理, 反向代理, 负载均衡, 静态文件服务器,websocket代理,四层TCP/UDP转发,内网穿透等,会将实 ...
- NC24727 [USACO 2010 Feb G]Slowing down
题目链接 题目 题目描述 Every day each of Farmer John's N (1 <= N <= 100,000) cows conveniently numbered ...
- CSS浮动&定位&布局
浮动简介 浮动最早起设计出来是为了实现文字环绕图片或者文字环绕的效果,现在浮动是主流的页面布局方式之一 float:浮动属性,值可以是left.right对应向左和向右浮动 元素浮动之后的特点 脱离文 ...
- Java并发编程实例--16.使用ReentrantLock实现线程同步
Java提供另一机制去同步代码块.它比synchronized关键字更强大且易用. 它是基于Lock接口和其实现类例如:ReentrantLock. 这一机制对比synchronized关键字的优势在 ...
- 责任链模式与spring容器的搭配应用
背景 有个需求,原先只涉及到一种A情况设备的筛选,每次筛选会经过多个流程,比如先a功能,a功能通过再筛选b功能,然后再筛选c功能,以此类推.现在新增了另外一种B情况的筛选,B情况同样需要A情况的筛选流 ...
- QT - Day 6
跟着视频教程创建了翻金币的项目,花了好几个晚上才学习完. 视频地址:最新QT从入门到实战 感谢视频的教学,真是受益匪浅. 后面的代码参考了老师的模板以及文档的抒写格式. 发布到随笔中的目的一方面为了完 ...
- kubernetes(k8s)大白学习01-kubernetes是什么?有什么用?
kubernetes(k8s)大白基础学习-kubernetes是什么? 一.认识 Docker Docker 是什么 先来看看 Docker 的图标: 一条鲸鱼背上驮着四方形块的物品,就像一条海运船 ...
- 【Android 逆向】VM Kali 中 charles 抓android https 协议
1. 虚拟机调成桥接模式(不用选择 复制物理网络链接状态) 2. 虚拟机中 打开 Charles 4. 选择 Proxy ->SSL Proxying Settings 1. 选择SSL Pro ...