匹配一个文件夹下的所有excel——python

匹配一个文件夹下的所有excel------python(这里写自定义目录标题)

下面展示使用OID匹配所有excel文件的 代码片。这里的OID对应你匹配的基准变量。

首先,保证所有文件中都存在OID,且对应的目标样本相同。

然后,将路径(文件保存地址)和OID换成自己的就可以了

javascript 复制代码
#导入相关库
import os
import pandas as pd

# 设置文件夹路径,这里""中改成你自己的路径
excel_folder = r"C:\Users\lenovo\Desktop\map"

# 获取文件夹中所有 Excel 文件
excel_files = [f for f in os.listdir(excel_folder) if f.endswith('.xls') or f.endswith('.xlsx')]

# 初始化一个空的 DataFrame 用于合并所有结果
merged_df = pd.DataFrame()

# 遍历每个 Excel 文件
for excel_file in excel_files:
    try:
        # 构建文件路径
        excel_path = os.path.join(excel_folder, excel_file)

        # 读取 Excel 文件
        df = pd.read_excel(excel_path)

        # 检查是否包含 'OID' 列
        if 'OID' in df.columns:
            # 如果是第一个文件,则初始化 merged_df
            if merged_df.empty:
                merged_df = df
            else:
                # 基于 'OID' 列进行合并
                merged_df = pd.merge(merged_df, df, on='OID', how='outer')

            print(f"Successfully processed {excel_file}.")
        else:
            print(f"Warning: 'OID' column not found in {excel_file}. Skipping file.")

    except Exception as e:
        print(f"Error processing {excel_file}: {e}")

# 导出合并后的结果到新的 Excel 文件
output_path = os.path.join(excel_folder, "merged_output.xlsx")
merged_df.to_excel(output_path, index=False)

print(f"All processing complete. Results saved to {output_path}")
相关推荐
hvinsion1 分钟前
【开源工具】超全Emoji工具箱开发实战:Python+PyQt5打造跨平台表情管理神器
python·qt·开源·emoji·表情包
羑悻的小杀马特15 分钟前
【C++高并发内存池篇】性能卷王养成记:C++ 定长内存池,让内存分配快到飞起!
开发语言·c++·c++项目·高性能内存池·定长内存池
冬天vs不冷21 分钟前
Java基础(二):八种基本数据类型详解
java·开发语言·php
燃犀知不可乎骤得1 小时前
qt控制台程序与qt窗口程序在读取数据库中文字段的差异!!巨坑
开发语言·数据库·qt
是数学系的小孩儿2 小时前
20250531MATLAB三维绘图
开发语言·数学·matlab·电脑
开开心心就好2 小时前
免费批量文件重命名软件
vue.js·人工智能·深度学习·typescript·pdf·excel·less
oioihoii2 小时前
C++和C#界面开发方式的全面对比
开发语言·c++·c#
x_feng_x2 小时前
Java从入门到精通 - 常用API(一)
java·开发语言·python
Dovis(誓平步青云)2 小时前
C++ Vector算法精讲与底层探秘:从经典例题到性能优化全解析
开发语言·c++·经验分享·笔记·算法
蹦蹦跳跳真可爱5894 小时前
Python----目标检测(《Fast R-CNN》和Fast R-CNN)
人工智能·python·深度学习·神经网络·目标检测·cnn