Python Pandas 库:解锁 combine、update 和compare函数的强大功能
liuian 2025-05-14 14:50 44 浏览
在 Python 的数据处理领域,Pandas库提供了丰富且实用的函数,帮助我们高效地处理和分析数据。今天,咱们就来深入探索 Pandas 库中四个功能独特的函数:combine、combine_first、update和compare。掌握了它们,我们在数据处理的道路上将会如虎添翼!
一、combine 函数:灵活的数据合并与计算
combine函数使用func将一个 DataFrame 与另一个DataFrame 进行合并,默认按列进行合并,新生成的 DataFrame 的行索引和列索引将是这两个DataFrame 索引的并集,最后返回生成的新的DataFrame对象。
函数原型
DataFrame.combine(other, func, overwrite=True, fill_value=None) |
2. 参数详解
- other:这是要与调用者(即当前 DataFrame 或 Series)进行合并计算的另一个 DataFrame。
- func:这是一个关键参数,它是一个自定义函数,用于指定如何对两个对应元素进行计算。这个函数接收两个参数,分别是调用者和other中的对应元素,返回值则是合并后的结果。
- fill_value:指定在其中一个对象中存在缺失值时使用这个填充值,然后再做合并处理。
- overwrite:如果 overwrite=True(默认值),则在组合操作中,如果新数据(来自 other 对象)中有值,将覆盖原始数据中的对应值。如果 overwrite=False,则只有在原始数据中为缺失值(NaN 或 None)的位置,才会用新数据中的值进行填充,不会覆盖原始数据中已有的非缺失值。
3. 示例
1)定义两个没有空值的DataFrame定义一个lamada函数,然后合并
import pandas as pd
df1 = pd.DataFrame({'A': [0, 0], 'B': [4, 4]})
df2 = pd.DataFrame({'A': [1, 1], 'B': [3, 3]})
print(df1)
print(df2)
take_smaller = lambda s1, s2: s1 if s1.sum() < s2.sum() else s2
df3 = df1.combine(df2, take_smaller)
print(df3)输出结果:
A B
0 0 4
1 0 4
A B
0 1 3
1 1 3
#合并的df3显示如下
A B
0 0 3
1 0 32)定义有空值的DataFrame,不传fill_value参数然后合并
import pandas as pd
df1 = pd.DataFrame({'A': [0, 0], 'B': [None, 4]})
df2 = pd.DataFrame({'A': [1, 1], 'B': [3, 3]})
print(df1)
print(df2)
take_smaller = lambda s1, s2: s1 if s1.sum() < s2.sum() else s2
df3 = df1.combine(df2, take_smaller)
print(df3)输出结果:
A B
0 0 NaN
1 0 4.0
A B
0 1 3
1 1 3
#合并的df3显示如下,B列直接返回df1中有空值的列
A B
0 0 NaN
1 0 4.03)定义有空值的DataFrame,传fill_value参数然后合并
import pandas as pd
df1 = pd.DataFrame({'A': [0, 0], 'B': [None, 4]})
df2 = pd.DataFrame({'A': [1, 1], 'B': [3, 3]})
print(df1)
print(df2)
take_smaller = lambda s1, s2: s1 if s1.sum() < s2.sum() else s2
#指定fill_value=-1
df3 = df1.combine(df2, take_smaller,fill_value=-1)
print(df3)输出结果:
A B
0 0 NaN
1 0 4.0
A B
0 1 3
1 1 3
#合并的df3显示如下,df1中的B列填充值之后带入函数做计算
A B
0 0 -1.0
1 0 4.04)定义两个没有空值的DataFrame,索引和列名不一致,对比overwrite为True和False时的输出结果
import pandas as pd
df1 = pd.DataFrame({'A': [0, 0], 'B': [4, 4]})
df2 = pd.DataFrame({'B': [1, 1], 'C': [3, 3]}, index=[1, 2]
)
print(df1)
print(df2)
take_smaller = lambda s1, s2: s1 if s1.sum() < s2.sum() else s2
df3 = df1.combine(df2, take_smaller)
print(df3)输出结果:
A B
0 0 4
1 0 4
B C
1 3 -10
2 3 1
#合并的df3显示如下
A B C
0 NaN NaN NaN
1 NaN 3.0 -10.0
2 NaN 3.0 1.0df3的A列因为df2无A列,填充的都为NAN值,索引为0的B列和C列填充的为NAN值
当overwrite=False时:
df3 = df1.combine(df2, take_smaller,overwrite=False)
print(df3)输出结果为:df3的A列索引为0和1的位置并没有填充为df2的NAN值,而是填充的df1的值。
A B C
0 0.0 NaN NaN
1 0.0 3.0 -10.0
2 NaN 3.0 1.0二、combine_first 函数:填充缺失值的利器
combine_first函数主要用于将两个 DataFrame 进行合并,用一个对象中的非缺失值去填充另一个对象中的缺失值,并返回这个新的DataFrame对象。
函数原型
参数other为另一个被合并的DataFrame对象。
使用方式类似:df.combine_first(other)
示例
设置两个 DataFrame,一个DataFrame有缺失值,进行合并
import pandas as pd
import numpy as np
# 创建示例 DataFrame
df1 = pd.DataFrame({'A': [1, np.nan, 3], 'B': [4, np.nan, 6]})
df2 = pd.DataFrame({'A': [7, 8, 9], 'B': [10, 11, 12]})
print(df1)
print(df2)
# 使用 combine_first 函数
result = df1.combine_first(df2)
print(result)输出结果:df1中的NAN值被df2中的值填充
A B
0 1.0 4.0
1 NaN NaN
2 3.0 6.0
A B
0 7 10
1 8 11
2 9 12
#合并后的结果
A B
0 1.0 4.0
1 8.0 11.0
2 3.0 6.0三、update 函数:选择性的数据更新
update函数用于根据条件对 DataFrame 中的数据进行更新,它会用另一个 DataFrame 中的数据替换调用者中匹配索引和列的数据,不会返回新的DataFrame对象。
1. 函数原型
DataFrame.update(other, join='left', overwrite=True, filter_func=None,errors='ignore') |
2. 参数详解
- other:用来更新当前 DataFrame 的另一个 DataFrame ,它的索引和列需要与调用者有一定的匹配关系。
- join:指定连接方式,'left'(默认值)表示左连接,只更新调用者中存在的索引和列的数据;不支持其他连接方式。
- overwrite:布尔值,默认为True,表示覆盖匹配到的原有的数据。如果为False,则只更新当前DataFrame的缺失值。
- filter_func:一个可选的函数,用于过滤要更新的数据。它接收一个 DataFrame 作为参数,返回一个布尔类型的 DataFrame,只有对应为True的位置的数据才会被更新。
- errors:指定如何处理错误。'ignore' (默认值)表示忽略错误并继续执行,'raise' 表示遇到错误时抛出异常。
3. 示例
1)有两个DataFrame,df1有缺失值,配置参数overwrite=False,只更新df1中的缺失值
import pandas as pd
import numpy as np
# 创建示例 DataFrame
df1 = pd.DataFrame({'A': [1, np.nan, 3], 'B': [4, np.nan, 6],'C': [5, 8, 9]}, index=[1, 2, 3])
df2 = pd.DataFrame({'A': [7, 8, 9], 'B': [10, 11, 12]})
print(df1)
print(df2)
# 使用 update 函数更新df1
df1.update(df2,overwrite=False)
print(df1)输出结果:因为两个DataFrame索引和列数都不完全一致,只匹配到索引为1和2的A列和B列。
因此只有第2行的A列和B列原先为NAN值,被df2中的值更新,其他数据都不更新
A B C
1 1.0 4.0 5
2 NaN NaN 8
3 3.0 6.0 9
A B
0 7 10
1 8 11
2 9 12
#更新后的值
A B C
1 1.0 4.0 5
2 9.0 12.0 8
3 3.0 6.0 9如果overwrite=True,则输出结果如下:索引为1和2的A列和B列都被更新
#更新后的值
A B C
1 8.0 11.0 5
2 9.0 12.0 8
3 3.0 6.0 9 2)有两个DataFrame,df1有缺失值,添加一个lambda函数只更新偶数值
import pandas as pd
import numpy as np
# 创建示例 DataFrame
df1 = pd.DataFrame({'A': [1, np.nan, 3], 'B': [4, np.nan, 6],'C': [5, 8, 9]})
df2 = pd.DataFrame({'A': [7, 8, 9], 'B': [10, 11, 12]})
print(df1)
print(df2)
# 使用 update 函数更新df1
df1.update(df2, filter_func=lambda x:x%2==0)
print(df1)输出结果:更新了索引为0和2的B列中的偶数,替换为了df2中的值。
A B C
0 1.0 4 5
1 NaN 3 8
2 3.0 6 9
A B
0 7 10
1 8 11
2 9 12
#更新后的值
A B C
0 1.0 10 5
1 NaN 3 8
2 3.0 12 9
四、compare 函数:数据差异的 “放大镜”
在实际的数据工作中,compare函数的作用就是直观地展示两个DataFrame之间的不同之处,将数据差异清晰地呈现出来,就像给数据差异加上了一个 “放大镜”,让我们一眼就能捕捉到关键信息。
函数原型
DataFrame.compare(other,align_axis=1,keep_shape=False,keep_equal=False,result_names=("self","other")
2. 参数详解
- other:代表要与调用者(当前DataFrame)进行对比的另一个DataFrame,两个DataFrame需要有相同的索引和行列数,不一致会报错。
- align_axis:指定对齐轴,默认值为1(按列比较)。当设置为0时,则按行比较。
- keep_shape:布尔值,默认值为False。设置为True,则会保留原有的形状,即使某些列或行在对比中没有差异也会显示,只是填充为缺失值。
- keep_equal:布尔值,默认值为False。设置为True,会保留两个DataFrame中相等的元素,在结果中用NaN来表示相等的部分。
- result_names:表示对比差异显示的两个DataFrame的名称,默认显示为self和other。
示例
创建两个DataFrame,第一行的数据是相同的。
import pandas as pd
import numpy as np
# 创建示例 DataFrame
df1 = pd.DataFrame({'A': [1, 2, 3], 'B': [4, 5, 6]})
df2 = pd.DataFrame({'A': [1, 4, 3], 'B': [4, 7, 8]})
print(df1)
print(df2)输出结果:
A B
0 1 4
1 2 5
2 3 6
A B
0 1 4
1 4 7
2 3 8示例 1:使用 compare 函数,设置 result_names=('df1','df2')
diff_df = df1.compare(df2,result_names=('df1','df2'))
print(diff_df)输出结果:
A B
df1 df2 df1 df2
1 2.0 4.0 5.0 7.0
2 NaN NaN 6.0 8.0
示例 2:使用 compare 函数,设置align_axis=0按行比较
diff_df_axis = df1.compare(df2,align_axis=0)
print(diff_df_axis)输出结果:
A B
1 self 2.0 5.0
other 4.0 7.0
2 self NaN 6.0
other NaN 8.0
示例 3:使用 compare 函数,设置 keep_shape=True
diff_df_keep_shape = df1.compare(df2, keep_shape=True)
print(diff_df_keep_shape)输出结果:
A B
self other self other
0 NaN NaN NaN NaN
1 2.0 4.0 5.0 7.0
2 NaN NaN 6.0 8.0
示例 4:使用 compare 函数,设置 keep_equal=True
diff_df_keep_equal = df1.compare(df2, keep_equal=True)
print(diff_df_keep_equal)
输出结果:
A B
self other self other
1 2 4 5 7
2 3 3 6 8共勉: 东汉·班固《汉书·枚乘传》:“泰山之管穿石,单极之绠断干。水非石之钻,索非木之锯,渐靡使之然也。”
-----指水滴不断地滴,可以滴穿石头;
-----比喻坚持不懈,集细微的力量也能成就难能的功劳。
----感谢读者的阅读和学习,谢谢大家。
相关推荐
- 电脑如何设置防火墙(电脑如何设置防火墙其它软件禁止联网)
-
电脑防火墙设置方法如下1、首先,我们打开我们的电脑,然后我们双击电脑桌面上的控制面板;2、进入控制面板之后,我们点击WindowsDefender防火墙;3、弹出的界面,我们点击启用或关闭Windo...
-
- through(through和by的区别)
-
区别by表示方法,手段。through表示以、通过、经由。在表示手段时,by,through有时也可换用by1、表示方法,手段。即“用...通过...相当于bymeansof如:Allworkhadtobedone...
-
2026-01-13 16:55 liuian
- bizhub15打印机驱动下载(bizhub打印机驱动安装)
-
1、请用USB数据线连接复印机和电脑。 2、打开电脑,然后到复印机的官网下载当前系统的驱动程序,然后点击安装。 3、安装完成后,点击打开打印机和传真,就可以到看扫描仪的图标。 4、找个要扫描的内...
- win7电脑截屏(windows7电脑截屏)
-
在Win7系统中,自带的截图快捷键是“PrtScn”键,即PrintScreen键。按下这个键后,系统会将当前屏幕的内容复制到剪贴板中,然后用户可以将其粘贴到其他应用程序中进行编辑或保存。此外,Wi...
- win10电脑所有软件都打不开(win10任何软件都打不开)
-
具体步骤如下:萊垍頭條1、如果遇到这类情况,你先看下快捷键alt+tab键能否查看,并把鼠标放在任务栏的图标上,或者查看一下窗口的缩略图。萊垍頭條2、我们将鼠标放在任务栏上,选中打不开的软件,然后al...
- 如何创建电子邮件账号(如何创建电子邮件账号在outlook中)
-
用QQ号的一键激活邮箱几乎是最快,最简单的注册邮箱手段了,且QQ邮箱功能强大,安全方便,推荐你使用,具体注册方法如下:1、你可以点击QQ面板邮箱快捷按钮,直接激活邮箱。2、如果你没有QQ,直接申请QQ...
- 戴尔音频驱动下载(戴尔电脑声卡驱动下载)
-
1、如果是笔记本没有音频设备的话,并不是没有输出设备,而是我们没有启用或者没有安装音频驱动导致的。先打开控制面板。2、打开控制面板之后下面依次找到音频清晰管理器,并且打开。3、打开之后我们这里把主音量...
- toshiba硬盘(TOSHIBA硬盘tlc)
-
东芝移动硬盘a3好,性价比很高,传输速率高,稳定耐用,安全高效外壳是磨砂质感!USB3.0,即插即用采用NTFS格式,兼容Windwos10、Windwos8.1、Windwos7,格式化后可兼容M...
- 完整版xp系统下载(xp系统最新版本安装包)
-
2012年前的可以无压力安装XP系统,搜索:itellyou.cn这里有WINDOWS几乎所有的系统。windowsXP系统升级的具体操作步骤如下:1、首先我们将老毛桃装机工具下载到U盘,将老毛桃...
- ps下载电脑版官方下载(ps电脑版下载地址)
-
目前在电脑上免费下载PS是不太可能的。主要有以下几个原因。1.AdobePhotoshop(简称PS)是一款商业软件,它需要用户购买和激活许可证才能合法使用。从正规渠道下载并且获得合法授权需要付费...
- 迅猛兔加速器(迅猛兔加速器官网)
-
要下载迅猛兔加速器,首先需要在官网或其他可信的下载平台上搜索并找到该软件。一般情况下,官网提供的下载链接是最稳定和安全的选择。在下载之前,确保您的电脑或手机系统能够支持使用此软件,并检查下载链接的文件...
- 台式电脑怎么重做系统(台式电脑怎么重装系统)
-
你好,电脑系统重装的步骤如下:1.备份数据:在重装系统之前,需要备份电脑中的重要数据,以免数据丢失。2.准备安装介质:需要准备一个安装介质,可以是光盘、U盘或者硬盘分区镜像等。3.设置启动顺序:将电脑...
-
- 电脑无法从u盘启动怎么办(电脑无法从u盘启动解决方法)
-
电脑的进入不了u盘启动的解决方法:一、我们第一步需要确定的是你的u盘在别的电脑上检查一下U盘是否可读,如果可读的话是否成功制作了u盘启动盘了,因为想要启动进入pe的话需要u盘具备启动的功能。 二、如果你检查好自己的u盘已经成功制作了启动盘...
-
2026-01-13 10:05 liuian
- 一周热门
-
-
飞牛OS入门安装遇到问题,如何解决?
-
如何在 iPhone 和 Android 上恢复已删除的抖音消息
-
Boost高性能并发无锁队列指南:boost::lockfree::queue
-
大模型手册: 保姆级用CherryStudio知识库
-
用什么工具在Win中查看8G大的log文件?
-
如何在 Windows 10 或 11 上通过命令行安装 Node.js 和 NPM
-
威联通NAS安装阿里云盘WebDAV服务并添加到Infuse
-
Trae IDE 如何与 GitHub 无缝对接?
-
idea插件之maven search(工欲善其事,必先利其器)
-
如何修改图片拍摄日期?快速修改图片拍摄日期的6种方法
-
- 最近发表
- 标签列表
-
- 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)
