文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Python处理数据:匹配两个Excel文件数据

2023-09-21 09:51

关注

当需要处理两个Excel文件的数据,根据两个Excel的某一些内容进行数据匹配,从而提取出相应的数据时,除了使用Excel自带的Vlookup函数,还能使用Python进行处理。我是不会告诉你们我选择Python处理的原因是对Excel的Vlookup不熟悉的。

目录

1 前言自述

2 需求场景

3 代码实现

4 运行结果


1 前言自述

这是我在工作中遇到的一个数据处理需求问题,该问题有两种解决方式,一种是Office高效办公,一种是Python高效办公。是的,我选择了后者。将解决该问题的过程记录下来,作为我使用Python高效办公的一个纪念。在最后,为了方便其他没有Python的同事使用,我还尝试将该程序进行了打包处理,发现虽然能打包,但是代码行数增加了不少。因此,建议有Python基础的朋友还是直接使用代码比用打包好的程序比较好。

2 需求场景

有两个excel文件,都放了大量的数据:

第一个excel文件:

第二个excel文件:

需求是:将两个excel文件中的数据进行匹配,当两个excel文件中的项目名称和项目号都一样的时候,将第二个excel文件中的合同号填入到第一个文件中的合同号中。即匹配两列相同列名的数据,当对应行数的数据一模一样的时候,在第一个excel文件中标记新的数据出来。在这种情况下,通常是会面对大量数据,即两个excel文件有上千条数据。为了 方便理解,我将第二个文件中的不同用颜色标了出来。

举个例子:第二个excel文件中有两个项目名称A7(第三行和第七行),但对应项目号能和第一个excel文件匹配得上的只有第3行,因此此时需要将第二个excel文件中第三行的合同号填入到第一个excel文件的序号7行对应的合同号列表中。

3 代码实现

import pandas as pd# 读取excel1和excel2数据total_table = pd.read_excel('第一个excel文件.xlsx')subset_table = pd.read_excel('第二个excel文件.xlsx')# 在第一个excel中添加新列total_table['合同号'] = ""# 根据第二个excel数据进行匹配和填充合同号for index, row in subset_table.iterrows():    # 获取分表中的两列内容    column1_match = row['项目名称']    column2_match = row['项目号']    # 在第一个excel中查找匹配行    matched_rows = total_table.loc[(total_table['项目名称'] == column1_match) & (total_table['项目号'] == column2_match)]    # 填充合同号    total_table.loc[matched_rows.index, '合同号'] = row['合同号']# 保存修改后的第一个excel数据到新的文件total_table.to_excel('新增合同号的excel文件.xlsx', index=False)

4 运行结果

来源地址:https://blog.csdn.net/weixin_44494624/article/details/132214730

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯