Pandas多列匹配赋值方法详解
文章小白一枚,正在不断学习积累知识,现将学习到的知识记录一下,也是将我的所得分享给大家!而今天这篇文章《Pandas多列匹配赋值技巧》带大家来了解一下##content_title##,希望对大家的知识积累有所帮助,从而弥补自己的不足,助力实战开发!
在数据分析和处理中,我们经常面临这样的需求:根据DataFrame中现有列的特定条件来创建或更新新的列。一个常见的挑战是,当这些条件涉及到多列之间的复杂逻辑(例如,查找不同列组之间的匹配项)时,如何高效地进行数据填充。传统的逐行迭代(如使用df.iterrows())方法在处理大型数据集时效率极低,容易导致性能瓶颈。为了解决这一问题,Pandas和NumPy提供了强大的向量化操作,能够显著提升数据处理效率。
挑战:DataFrame列的条件填充
假设我们有一个DataFrame,其中包含多对相关的列,例如CellName1和CellName1value,CellName2和CellName2value等。我们的目标是新增两列resultcellname和resultcellnamevalue,并根据这些CellName和CellNameValue对之间的匹配情况来填充它们。例如,如果CellName1和CellName1value与CellName2和CellName2value完全匹配,我们就将CellName1和CellName1value的值填充到新列中。如果存在多个匹配条件,可能还需要考虑优先级。
解决方案:利用NumPy的np.where进行向量化操作
NumPy库中的np.where()函数是进行条件赋值的强大工具。它的基本语法是: numpy.where(condition, value_if_true, value_if_false)
- condition: 一个布尔型数组或Series,表示条件。
- value_if_true: 当条件为True时,对应位置填充的值。
- value_if_false: 当条件为False时,对应位置填充的值。
np.where()的优势在于其向量化特性,它可以在整个数组或Series上同时应用条件,而无需显式的循环,从而大大提高处理速度。
实战案例:多列匹配与结果填充
为了更好地理解如何应用np.where解决多列匹配问题,我们创建一个模拟的DataFrame,并演示如何根据不同CellName和CellNameValue对的匹配情况来填充resultcellname和resultcellnamevalue。
示例数据准备:
import pandas as pd import numpy as np # 模拟输入DataFrame data = { 'CellName1': ['A', 'B', 'C', 'D', 'E', 'F'], 'CellName1value': [10, 20, 30, 40, 50, 60], 'CellName2': ['A', 'X', 'C', 'Y', 'E', 'F'], 'CellName2value': [10, 25, 30, 45, 50, 65], # Note: F value differs 'CellName3': ['Z', 'B', 'P', 'D', 'Q', 'F'], 'CellName3value': [15, 20, 35, 40, 55, 60] } dfH = pd.DataFrame(data) # 初始化新的结果列,使用NaN或空字符串作为默认值 dfH['resultcellname'] = np.nan # 或 '' dfH['resultcellnamevalue'] = np.nan # 或 '' print("原始DataFrame:") print(dfH)
应用匹配逻辑并填充新列:
我们的目标是:
- 如果CellName1和CellName1value与CellName2和CellName2value匹配,则将CellName1和CellName1value填充到结果列。
- 如果CellName1和CellName1value与CellName3和CellName3value匹配,则将CellName1和CellName1value填充到结果列(这会覆盖前一个条件的结果,如果两者都匹配)。
- 如果CellName2和CellName2value与CellName3和CellName3value匹配,则将CellName2和CellName2value填充到结果列(这会覆盖之前的所有结果,如果匹配)。
这种链式np.where调用的顺序决定了匹配的优先级,后一个条件会覆盖前一个条件的结果。
# 1. 检查 CellName1/value 与 CellName2/value 是否匹配 condition_1_2 = (dfH['CellName1'] == dfH['CellName2']) & \ (dfH['CellName1value'] == dfH['CellName2value']) dfH['resultcellname'] = np.where(condition_1_2, dfH['CellName1'], dfH['resultcellname']) dfH['resultcellnamevalue'] = np.where(condition_1_2, dfH['CellName1value'], dfH['resultcellnamevalue']) # 2. 检查 CellName1/value 与 CellName3/value 是否匹配 # 如果当前行已经有result值,且此条件也匹配,则会覆盖 condition_1_3 = (dfH['CellName1'] == dfH['CellName3']) & \ (dfH['CellName1value'] == dfH['CellName3value']) dfH['resultcellname'] = np.where(condition_1_3, dfH['CellName1'], dfH['resultcellname']) dfH['resultcellnamevalue'] = np.where(condition_1_3, dfH['CellName1value'], dfH['resultcellnamevalue']) # 3. 检查 CellName2/value 与 CellName3/value 是否匹配 # 再次覆盖,此条件具有最高优先级 condition_2_3 = (dfH['CellName2'] == dfH['CellName3']) & \ (dfH['CellName2value'] == dfH['CellName3value']) dfH['resultcellname'] = np.where(condition_2_3, dfH['CellName2'], dfH['resultcellname']) dfH['resultcellnamevalue'] = np.where(condition_2_3, dfH['CellName2value'], dfH['resultcellnamevalue']) print("\n填充后的DataFrame:") print(dfH)
代码解析:
- 条件构建: 每个condition_X_Y变量都是一个布尔Series,通过&(逻辑与)运算符组合了两个条件:CellName是否相等和CellNamevalue是否相等。
- np.where应用: 每次调用np.where时,如果condition为True,则将相应的CellName或CellNamevalue填充到结果列中;如果为False,则保留resultcellname或resultcellnamevalue当前的值。这意味着,如果一个位置已经通过前一个np.where调用被填充了,而当前np.where的条件不满足,那么之前填充的值会保留下来。反之,如果当前条件满足,则会覆盖之前的值。这种“后一个覆盖前一个”的逻辑使得我们可以设置条件的优先级。
- 初始化: 在开始之前,将resultcellname和resultcellnamevalue初始化为np.nan(对于数值)或空字符串(对于字符串),确保在没有任何条件匹配时,这些列有明确的默认值。
注意事项与最佳实践
- 避免逐行迭代: 始终优先考虑使用Pandas和NumPy提供的向量化操作(如np.where、Series/DataFrame方法)而不是for循环和iterrows(),尤其是在处理大型数据集时。向量化操作通常在底层使用C语言实现,效率远高于Python层面的循环。
- 数据类型一致性: 确保参与比较的列具有兼容的数据类型。例如,字符串和数值类型不能直接进行有意义的相等比较。如果需要,进行适当的类型转换。
- 初始值设置: 根据业务需求选择新列的初始值。np.nan是数值列的常见选择,而空字符串''或None适用于对象(字符串)列。
- 逻辑优先级: 如果存在多个匹配条件,并且希望按照特定优先级填充结果,需要仔细安排np.where语句的顺序。后执行的np.where会覆盖前一个的结果。
- 可读性: 对于复杂的条件,可以先将每个子条件或布尔掩码存储在单独的变量中,提高代码的可读性和可维护性。
- 链式操作与内存: 连续的np.where操作会在每次赋值时创建新的Series对象。对于极大的DataFrame,这可能会短暂增加内存使用,但在大多数情况下是可接受的。
总结
通过本教程,我们学习了如何利用Pandas和NumPy的np.where函数高效地为DataFrame新增列并根据复杂的多列匹配条件进行填充。这种向量化的方法不仅显著提升了数据处理性能,也使代码更加简洁和易于维护。掌握这种技巧是进行高效数据操作的关键一步,能够帮助您在处理大规模数据集时避免常见的性能陷阱。
本篇关于《Pandas多列匹配赋值方法详解》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于文章的相关知识,请关注golang学习网公众号!

- 上一篇
- CSS替代表格的使用方法与优势分析

- 下一篇
- Java小程序数据导入导出方法详解
-
- 文章 · python教程 | 8分钟前 |
- Numba加速NumPy浮点映射方法
- 178浏览 收藏
-
- 文章 · python教程 | 16分钟前 |
- PandasDataFrame列类型与唯一值统计方法
- 386浏览 收藏
-
- 文章 · python教程 | 1小时前 |
- 字符串处理:分割、替换与拼接技巧
- 459浏览 收藏
-
- 文章 · python教程 | 1小时前 |
- Python读取DICOM医疗数据全攻略
- 316浏览 收藏
-
- 文章 · python教程 | 1小时前 |
- 递归实现西Syracuse序列的Python教程
- 385浏览 收藏
-
- 文章 · python教程 | 1小时前 |
- Python操作PPT教程:python-pptx使用指南
- 408浏览 收藏
-
- 文章 · python教程 | 1小时前 |
- Python模板引擎使用技巧全解析
- 402浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 511次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 498次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- AI歌曲生成器
- AI歌曲生成器,免费在线创作,简单模式快速生成,自定义模式精细控制,多种音乐风格可选,免版税商用,让您轻松创作专属音乐。
- 6次使用
-
- MeloHunt
- MeloHunt是一款强大的免费在线AI音乐生成平台,让您轻松创作原创、高质量的音乐作品。无需专业知识,满足内容创作、影视制作、游戏开发等多种需求。
- 6次使用
-
- 满分语法
- 满分语法是一款免费在线英语语法检查器,助您一键纠正所有英语语法、拼写、标点错误及病句。支持论文、作文、翻译、邮件语法检查与文本润色,并提供详细语法讲解,是英语学习与使用者必备工具。
- 15次使用
-
- 易销AI-专为跨境
- 易销AI是专为跨境电商打造的AI营销神器,提供多语言广告/产品文案高效生成、精准敏感词规避,并配备定制AI角色,助力卖家提升全球市场广告投放效果与回报率。
- 18次使用
-
- WisFile-批量改名
- WisFile是一款免费AI本地工具,专为解决文件命名混乱、归类无序难题。智能识别关键词,AI批量重命名,100%隐私保护,让您的文件井井有条,触手可及。
- 15次使用
-
- Flask框架安装技巧:让你的开发更高效
- 2024-01-03 501浏览
-
- Django框架中的并发处理技巧
- 2024-01-22 501浏览
-
- 提升Python包下载速度的方法——正确配置pip的国内源
- 2024-01-17 501浏览
-
- Python与C++:哪个编程语言更适合初学者?
- 2024-03-25 501浏览
-
- 品牌建设技巧
- 2024-04-06 501浏览