【Python】Python 读取Excel、DataFrame对比并选出差异数据,重新写入Excel

背景:我在2个系统下载出了两个Excel,现在通过对下载的2个Excel数据,并选出差异数据 从新写入一个新的Excel中

在这里插入图片描述


differences_url =r'C:\Users\LENOVO\Downloads\differences.xlsx'; //要生成的差异Excel的位置及名称
df1_url =r'C:\Users\LENOVO\Downloads\excel1.xlsx'; //要对比的源Excel1
df2_url =r'C:\Users\LENOVO\Downloads\excel2.xlsx';//要对比的源Excel2
# 步骤1: 读取两个Excel文件
df1 = pd.read_excel(df1_url)
df2 = pd.read_excel(df2_url)# 打印读取的数据
print("File 1 Data:")
print(df1)
print("\nFile 2 Data:")
print(df2)# 假设要比较的列是 '入库通知单号' 和 '来源平台'
comparison_columns = ['入库通知单号', '来源平台']# 合并两个 DataFrame,在相同 入库通知单号 上进行比较
df_merged = df1.merge(df2, on='入库通知单号', suffixes=('_file1', '_file2'), how='outer')
print("========>")
#df_merged.to_excel(r'C:\Users\LENOVO\Downloads\df_merged.xlsx', index=False)# 通过"入库通知单号"字段关联后,比对两个Excel中的"来源平台"字段找到不同的数据
differences = df_merged[(df_merged['来源平台_file1'] != df_merged['来源平台_file2']) | (df_merged['来源平台_file1'].isnull() | df_merged['来源平台_file2'].isnull())]# 打印比较结果
print("Differences between the two files:")
print(differences)# 检查文件是否存在  
if os.path.exists(differences_url):  # 如果文件存在,则删除它  os.remove(differences_url)  print(f"文件 {differences_url} 已存在,已被删除。") # 将比较结果输出到 Excel 文件
differences.to_excel(r'C:\Users\LENOVO\Downloads\differences.xlsx', index=False)

测试:
两个源Excel
在这里插入图片描述

excel1和excel2的都是一样的数据
在这里插入图片描述

对比后产生差异Excel
在这里插入图片描述
差异中差异数据是空的
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/419209.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

大数据新视界--大数据大厂之Java 与大数据携手:打造高效实时日志分析系统的奥秘

💖💖💖亲爱的朋友们,热烈欢迎你们来到 青云交的博客!能与你们在此邂逅,我满心欢喜,深感无比荣幸。在这个瞬息万变的时代,我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的…

Spring源码(3)Aware接口、初始化和销毁方法、@Scope、@Primary

1、目标 本文的主要目标是学习Spring源码中Aware接口、初始化和销毁方法、Scope注解、Primary注解的使用 2、Aware接口 Component public class MyBeanAware implements BeanNameAware, ApplicationContextAware {Overridepublic void setBeanName(String name) {System.out…

从JavaScript入门Go三

前情提要 上一章中我们讲了Go中的变量与函数,这一节我们说说Go中的逻辑语法for、if、switch。最近正好有空,正好给大家更新一下入门的第三章。 PS:没看过的第一章、第二章的小伙伴,可以进入下面的链接查看 从JavaScript入门Go一 从…

计算机毕业设计 | vue+springboot在线投稿管理 稿件文章报社管理系统 (附源码)

1,绪论 1.1 行业趋势与需求 随着互联网的发展和普及,越来越多的出版社、杂志社和媒体开始采用在线投稿系统。这种系统提供了一个便捷的平台,让作者可以直接将他们的文章提交到相应的出版机构,而无需邮寄或亲自递交稿件。这不仅节…

Web服务器配置管理

目录 一、设计内容: 二、摘 要 三、课题描述 四、需求分析 五、概要设计 六、详细设计 七、结果分析 八、总结 一、设计内容 Web服务器的安装与配置管理。 1.任务说明 C/S 模式的网络环境,包括一台Windows工作站和一台Windows Server 服务器。 2.要求 ①…

图论(2)

一、度 度统计的是一个节点上又多少条边 度出度入度 出度:统计以该节点为起始点箭头指向外面的边的条数 入度:统计箭头指向该节点的边数 度为1的节点为悬挂节点,边为悬挂边 用矩阵计算节点的度 二、握手定理 比如这里第一个集合里面有三…

35天学习小结

距离上次纪念日,已经过去了35天咯 算算也有5周了,在这一个月里,收获的也挺多,在这个过程中认识的大佬也是越来越多了hh 学到的东西,其实也没有很多,这个暑假多多少少还是有遗憾的~ 第一周 学习了一些有…

掌握Java对象本质:从打工者到技术专家的飞跃

1.1 从机器视角到问题视角的演变 在计算机科学的发展历程中,我们见证了从机器视角到问题视角的深刻转变。这一转变不仅体现了编程语言和技术的进步,更反映了我们对问题解决方式理解的深化。 起初,计算机编程主要依赖于机器视角。汇编语言作…

MACD指标精讲PART1:MACD指标入门及使用法则

一、MACD指标入门 MACD(Moving Average Convergence Divergence)指标称为指数平滑异同移动平均线指标,是由Geral Apple所创造,用来跟踪股价运行趋势、判断股票买卖时机的技术分析工具。 MACD指标由DIFF线(Difference线…

浅谈架构实战

目录 背景 1 架构演变 2 如何实现高层的复用 2 中台产生案例 3 技术架构的核心要点 4 技术架构的高可用案例 背景 业务架构、数据架构、应用架构和技术架构它们是相互关联和相互支持的,共同构成了企业的总体架构,业务架构是源头,然后才…

强推!创新直发核心!时序分解+优化组合+模型对比!VMD-SSA-Transformer-BiLSTM多变量时间序列预测

强推!创新直发核心!时序分解优化组合模型对比!VMD-SSA-Transformer-BiLSTM多变量时间序列预测 目录 强推!创新直发核心!时序分解优化组合模型对比!VMD-SSA-Transformer-BiLSTM多变量时间序列预测效果一览基…

如何将图表数据拟合为函数

1. 数据准备 收集图表数据,包括独立变量(如 x值)和因变量(如 y 值)。这些数据可以是离散的点,通常表示为一组 (x1,y1),(x2,y2),…,(xn,yn)。 2. 选择模型 选择拟合函数的模型。这取决于数据的特征及其在…

YOLO配合 PYQT做自定义虚拟电子围-自定义绘制多边形虚拟电子围栏

1、目标检测: YOLO可以识别检测物体,这是众所周知的。使用YOLO来做目标检测,并获取坐标信息。 2、电子围栏 比如在监控中,指定一块区域,如果有目标进入,则发出警报,并提示。比如下图标红的区…

使用rabbitmq发送消息和caffeineCache保存本地

目录 使用stock_job工程采集到国内大盘的最新交易时间的信息并插入数据库,使用rabbitmq发送消息 1.导入依赖 2.编写yml文件,配置连接rabbitmq的信息 3.编写mq的配置类,生成交换机,消息队列,并将他们绑定 4.采集最新…

Centos安装配置Gitea(Ubuntu等系统也可参考)

准备工作 安装好宝塔面板,再进入宝塔面板安装好MySQL,添加配置一个MySQL数据库gitea,用户名和密码也为gitea (也可用命令行做相关操作,自行搜索教程) 通过终端下载安装git,添加普通用户git&a…

《Nginx核心技术》第16章:实现Nginx的高可用负载均衡

作者:冰河 星球:http://m6z.cn/6aeFbs 博客:https://binghe.gitcode.host 文章汇总:https://binghe.gitcode.host/md/all/all.html 星球项目地址:https://binghe.gitcode.host/md/zsxq/introduce.html 沉淀&#xff0c…

网络安全AI大模型训练从入门到精通

前言 2022年下半年,国内安全圈内开始完chatGPT,当时在安全圈内小火了一把。大家纷纷注册去体验一把,希望chatGPT能帮助解决日常安服渗透问题。当时以为仅此而已,谁知年后大火,随后以chatGPT为代表的大语言模型&#x…

掌握Hive函数[3]:从基础到高级应用

目录 窗口函数(开窗函数) 概述 常用窗口函数 1)聚合函数 2)跨行取值函数 (1)LEAD 和 LAG (2)FIRST_VALUE 和 LAST_VALUE 3)排名函数 案例演示 1. 数据准备 1&…

数据库锁之行级锁、记录锁、间隙锁和临键锁

1. 行级锁 InnoDB 引擎支持行级锁,而MyISAM 引擎不支持行级锁,只支持表级锁。行级锁是基于索引实现的。 对于普通的select语句,是不会加记录锁的,因为它属于快照读,通过在MVCC中的undo log版本链实现。如果要在查询时对…

spring security 中的授权使用

一、认证 身份认证,就是判断一个用户是否为合法用户的处理过程。Spring Security 中支持多种不同方式的认证,但是无论开发者使用那种方式认证,都不会影响授权功能使用。因为 SpringSecurity 很好做到了认证和授权解耦。 二、授权 授权&#x…