使用Pandas高效合并DataFrame:基于字符串键提取与映射的教程

使用Pandas高效合并DataFrame:基于字符串键提取与映射的教程

本教程详细阐述了如何使用Python Pandas库,在两个DataFrame之间进行条件合并。当合并键存在于一个DataFrame的字符串列中,且需要提取数字部分与另一个DataFrame的索引或数字列匹配时,本教程提供了一种高效的解决方案。通过str.extract方法提取关键数字,并结合map函数实现精确的数据映射,从而避免了低效的循环操作,确保了代码的性能与可读性。

场景描述

在数据处理过程中,我们经常会遇到需要将两个数据集(dataframe)进行合并或关联的情况。然而,合并键的格式可能不尽相同,例如,一个dataframe的键是“1st”、“2nd”这样的字符串,而另一个dataframe的键是纯数字(1、2、3)。在这种情况下,直接使用merge函数可能无法达到预期效果,需要对键进行预处理。

假设我们有两个DataFrame,df1和df2,结构如下:

df1

birthdate ceremony_number

9/30/18951st7/23/18841st3/29/18892nd4/10/18683rd4/8/18922nd

df2

index dates

11929-05-1621930-04-0331930-11-05

我们的目标是根据df1中的ceremony_number列(例如,从“1st”中提取“1”)与df2的索引(或一个名为index的列)进行匹配,然后将df2中的dates列添加到df1中,作为新的date_oscar列。

数据准备

首先,我们创建示例DataFrame并进行基本的数据类型转换,特别是日期列,将其转换为Pandas的datetime对象,这有助于后续的数据操作和一致性。

import pandas as pd# 创建 df1data1 = {    'birthdate': {0: '9/30/1895', 1: '7/23/1884', 2: '3/29/1889',                  3: '4/10/1868', 4: '4/8/1892'},    'ceremony_number': {0: '1st', 1: '1st', 2: '2nd', 3: '3rd', 4: '2nd'}}df1 = pd.DataFrame(data1)# 创建 df2# 注意:df2的键是其索引,而不是一个单独的列data2 = {'dates': {1: '1929-05-16', 2: '1930-04-03', 3: '1930-11-05'}}df2 = pd.DataFrame(data2)# 将日期列转换为datetime对象df1['birthdate'] = pd.to_datetime(df1['birthdate'], format='%m/%d/%Y')df2['dates'] = pd.to_datetime(df2['dates'], format='%Y-%m-%d')print("原始 df1:")print(df1)print("n原始 df2:")print(df2)

输出:

原始 df1:   birthdate ceremony_number0 1895-09-30             1st1 1884-07-23             1st2 1889-03-29             2nd3 1868-04-10             3rd4 1892-04-08             2nd原始 df2:        dates1  1929-05-162  1930-04-033  1930-11-05

核心解决方案:提取与映射

解决此问题的关键在于两个步骤:

从df1[‘ceremony_number’]字符串中提取数字。使用提取出的数字作为键,将df2[‘dates’]的值映射到df1的新列中。

# 步骤1: 从 'ceremony_number' 列中提取数字# 使用正则表达式 '^(d+)' 匹配字符串开头的连续数字# expand=False 确保返回一个 Series 而不是 DataFrame# astype(int) 将提取到的字符串数字转换为整数类型,以便与 df2 的索引匹配extracted_numbers = df1['ceremony_number'].str.extract('^(d+)', expand=False).astype(int)# 步骤2: 使用 map 函数将 df2['dates'] 的值映射到 df1# map 方法接收一个 Series 或字典。当传入一个 Series 时,# map 会使用该 Series 的索引作为查找键,Series 的值作为映射结果。# 在这里,extracted_numbers 的每个值会作为键去 df2['dates'] 的索引中查找对应的值。df1['date_oscar'] = extracted_numbers.map(df2['dates'])print("n合并后的 df1:")print(df1)

输出:

合并后的 df1:   birthdate ceremony_number date_oscar0 1895-09-30             1st 1929-05-161 1884-07-23             1st 1929-05-162 1889-03-29             2nd 1930-04-033 1868-04-10             3rd 1930-11-054 1892-04-08             2nd 1930-04-03

关键技术解析

Series.str.extract(pat, expand=False):这是一个强大的字符串方法,用于从Series中的每个字符串元素中提取匹配正则表达式pat的子串。^(d+) 是一个正则表达式:^ 匹配字符串的开头。d+ 匹配一个或多个数字。() 创建一个捕获组,这意味着我们只提取括号内的内容。expand=False 参数确保返回一个Series,其中包含每个匹配的第一个捕获组。如果设置为True,则会返回一个DataFrame。Series.astype(int):将Series中的元素数据类型转换为整数。这是必要的,因为str.extract返回的是字符串,而df2的索引是整数。Series.map(arg):map方法是Pandas中用于元素级映射的利器。当arg是一个Series时,map会使用调用Series(这里是extracted_numbers)中的值作为键,去arg的索引中查找对应的值。如果某个键在arg的索引中找不到,则对应的结果将是NaN。

替代方案与注意事项

虽然map方法在此场景下非常高效和简洁,但也可以考虑其他方法:

DataFrame.merge():

如果df2的匹配键是一个常规列(而不是索引),或者需要进行更复杂的合并类型(如内连接、左连接等),merge会是更通用的选择。在使用merge之前,同样需要对df1[‘ceremony_number’]进行预处理,提取出数字,并可能需要重置df2的索引使其成为一个常规列。例如:

# df2_temp = df2.reset_index().rename(columns={'index': 'ceremony_index'})# df1['temp_key'] = df1['ceremony_number'].str.extract('^(d+)', expand=False).astype(int)# merged_df = pd.merge(df1, df2_temp, left_on='temp_key', right_on='ceremony_index', how='left')# df1['date_oscar'] = merged_df['dates']# df1.drop(columns=['temp_key'], inplace=True)

可以看出,map在添加单一列的场景下更为直接。

性能考量:

避免使用Python原生的for循环遍历DataFrame行,因为这通常效率低下,尤其对于大型数据集。Pandas的str访问器和map等方法都是高度优化的矢量化操作,能够显著提高性能。

缺失值处理:

如果extracted_numbers中的某个值在df2[‘dates’]的索引中找不到对应的项,map操作会自动填充NaN(Not a Number)值。在实际应用中,你可能需要进一步处理这些NaN值,例如填充默认值或删除包含NaN的行。

总结

本教程展示了如何利用Pandas的str.extract和map方法,高效地解决两个DataFrame之间基于字符串键提取数字进行数据关联的问题。这种方法不仅代码简洁,而且由于使用了Pandas的矢量化操作,性能也远优于传统的循环处理方式。掌握这些技巧,将有助于你更灵活、高效地处理复杂的数据合并任务。

以上就是使用Pandas高效合并DataFrame:基于字符串键提取与映射的教程的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1369993.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月14日 10:08:44
下一篇 2025年12月14日 10:08:47

相关推荐

  • 如何管理Python项目的依赖?

    答案:Python依赖管理核心在于隔离与精确控制,通过虚拟环境避免依赖冲突,结合pip、requirements.txt或更先进的Poetry、Rye等工具实现环境可复现;虚拟环境确保项目独立,现代工具如Poetry利用pyproject.toml和锁定文件提升依赖解析与一致性,处理复杂冲突时需版本…

    2025年12月14日
    000
  • JAX中利用vmap并行化模型集成:理解PyTree与结构化数组模式

    本教程深入探讨JAX中利用jax.vmap并行化模型集成时遇到的常见问题。核心在于理解vmap对PyTree中数组叶子的操作机制,而非直接处理Python列表。文章将详细阐述“列表结构”与“结构化数组”模式的区别,并提供使用jax.tree_map将模型参数转换为vmap友好格式的实用解决方案,从而…

    2025年12月14日
    000
  • 如何进行Python项目的日志管理?

    Python项目的日志管理,核心在于有效利用标准库 logging 模块,它提供了一套灵活且强大的机制来记录程序运行时的各种信息。通过合理配置日志级别、输出目标(文件、控制台、网络等)以及日志格式,我们不仅能追踪应用状态、诊断潜在问题,还能为后续的性能优化和安全审计提供关键数据。这绝不仅仅是打印几行…

    2025年12月14日
    000
  • 列表推导式、字典推导式与生成器表达式

    列表推导式、字典推导式和生成器表达式是Python中高效构建数据结构的工具,分别用于创建列表、字典和生成器对象。列表推导式适用于需多次访问结果的场景,语法为[表达式 for 变量 in 可迭代对象 if 条件];字典推导式用于构建键值映射,语法为{键表达式: 值表达式 for 变量 in 可迭代对象…

    2025年12月14日
    000
  • 如何判断一个数是否是质数?

    判断一个数是否是质数,核心是检查其是否有除1和自身外的因子,只需试除到平方根即可,因若存在大于平方根的因子,则必有对应的小于等于平方根的因子,故只需用2和3到√n的奇数试除,可高效判断。 判断一个数是否是质数,核心在于检查它除了1和自身之外,是否还有其他正整数因子。最直观的方法就是尝试用2到这个数平…

    2025年12月14日
    000
  • 如何理解Python的描述符(Descriptor)?

    描述符通过实现__get__、__set__等方法控制属性访问,解决属性验证、计算等重复逻辑问题;数据描述符因实现__set__而优先级高于实例字典,非数据描述符则可被实例属性覆盖,这一机制支撑了property、方法绑定等核心功能;自定义如TypeValidator类可复用验证逻辑,利用__set…

    2025年12月14日
    000
  • 深入理解Python列表推导式:高效生成复杂序列的两种策略

    本文探讨了如何利用Python列表推导式高效生成具有特定模式的复杂序列。我们将介绍两种主要策略:一是借助Python 3.8引入的赋值表达式(:=,即Walrus Operator)在推导式内部管理状态,适用于需要累积或依赖前一个状态的场景;二是识别序列的数学模式,通过直接的数学运算实现简洁高效的生…

    2025年12月14日
    000
  • Python基础:如何正确打印函数返回值

    在Python中,函数通过return语句返回计算结果,但这些结果并不会自动显示。要查看函数的输出,需要使用print()函数显式地打印函数的返回值。本文将通过示例详细解释这一常见初学者问题及其解决方案,帮助您理解return与print的区别,并正确地处理函数输出。 理解函数返回值与显示输出 py…

    2025年12月14日
    000
  • 如何进行Python项目的性能剖析(Profiling)?

    性能剖析是通过工具定位Python代码中耗时和资源消耗大的部分。首先用cProfile进行函数级分析,找出“时间大户”,再用line_profiler深入分析热点函数的逐行执行情况。两者结合实现从宏观到微观的优化。此外,还需关注内存(memory_profiler)、I/O(手动计时、数据库分析)和…

    2025年12月14日
    000
  • 如何部署一个机器学习模型到生产环境?

    部署机器学习模型需先序列化存储模型,再通过API服务暴露预测接口,接着容器化应用并部署至云平台或服务器,同时建立监控、日志和CI/CD体系,确保模型可扩展、可观测且可持续更新。 部署机器学习模型到生产环境,简单来说,就是让你的模型真正开始“干活”,为实际用户提供预测或决策支持。这并非只是把模型文件复…

    2025年12月14日
    000
  • 如何部署一个Python Web应用?

    答案:部署Python Web应用需搭建Nginx + Gunicorn + Flask/Django + Systemd技术栈,通过服务器配置、代码部署、Gunicorn服务管理、Nginx反向代理及SSL证书实现全球访问,该方案因高可控性、低成本和成熟生态成为“黄金标准”;Docker通过容器化…

    2025年12月14日
    000
  • 如何使用Python处理多任务?选择线程、进程还是协程?

    答案是根据任务类型选择:CPU密集型用进程,I/O密集型用协程,线程适用于简单并发但需注意GIL限制。 在Python中处理多任务,究竟是选择线程、进程还是协程,这确实是个老生常谈但又常新的问题。说实话,并没有一个放之四海而皆准的“最佳”方案。这就像你问一个厨师,做菜用刀还是用勺子好?答案肯定取决于…

    2025年12月14日
    000
  • 如何理解Python的WSGI标准?

    WSGI是Python中Web服务器与应用间的接口标准,定义了服务器通过传递environ和start_response调用应用的机制,实现解耦;其同步阻塞模型适合传统Web应用,而ASGI则支持异步和长连接,适用于高并发场景;典型部署使用Gunicorn或uWSGI作为WSGI服务器,Nginx作…

    2025年12月14日
    000
  • 如何使用asyncio库进行异步编程?

    答案:asyncio通过协程、事件循环和任务实现高效异步I/O,核心是async/await机制,避免阻塞并提升并发性能。协程由事件循环调度,任务是协程的封装,实现并发执行。常见陷阱包括使用阻塞调用和忘记await,应使用异步库、连接池、async with管理资源。调试可用asyncio调试模式和…

    2025年12月14日
    000
  • 如何检查一个字符串是否是回文?

    回文检查的核心是正读和反读一致,常用双指针法从两端向中间逐字符比较,若全部匹配则为回文。为提升实用性,需忽略大小写和非字母数字字符,可通过统一转小写并用正则或逐字符过滤预处理。更优方案是懒惰预处理,在双指针移动时动态跳过无效字符,避免额外空间开销。递归法逻辑清晰但性能较差,易因字符串切片和栈深度影响…

    2025年12月14日
    000
  • Python中的__slots__有什么作用?

    __slots__通过限制实例属性并避免创建__dict__来优化内存,适用于属性固定且对象数量庞大的场景,能显著减少内存占用,但会失去动态添加属性的能力,且影响弱引用和继承行为,实际效果需通过sys.getsizeof()和timeit等工具测量评估。 Python中的 __slots__ ,说白…

    2025年12月14日
    000
  • Python 中的浅拷贝与深拷贝:区别与应用场景

    浅拷贝创建新容器但共享内部元素,深拷贝递归复制所有层级确保完全独立。Python中通过切片、copy()实现浅拷贝,copy.deepcopy()实现深拷贝,前者高效但修改嵌套可变元素会影响原对象,后者开销大但隔离彻底。 Python中的浅拷贝与深拷贝,核心在于它们处理复合对象内部元素的方式不同。简…

    2025年12月14日
    000
  • 如何连接并操作主流数据库(MySQL, PostgreSQL)?

    连接数据库需掌握连接参数、选择工具并理解SQL操作。编程接口如Python通过驱动库(mysql-connector-python或psycopg2)建立连接,执行SQL语句并管理事务;客户端工具如MySQL Workbench、pgAdmin提供图形化操作界面。连接失败常见原因包括认证错误、权限限…

    2025年12月14日
    000
  • 谈谈你对Python上下文管理器的理解(with语句)。

    Python的with语句通过上下文管理器协议(__enter__和__exit__方法)实现资源的自动管理,确保其在使用后无论是否发生异常都能被正确释放。它简化了try…finally结构,广泛应用于文件操作、数据库事务、线程锁、临时状态更改和测试mock等场景,提升代码可读性与可靠性…

    2025年12月14日
    000
  • 如何使用Python进行机器学习(Scikit-learn基础)?

    答案:Scikit-learn提供系统化机器学习流程,涵盖数据预处理、模型选择与评估。具体包括使用StandardScaler等工具进行特征缩放,SimpleImputer处理缺失值,OneHotEncoder编码类别特征,SelectKBest实现特征选择;根据问题类型选择分类、回归或聚类模型,结…

    2025年12月14日
    000

发表回复

登录后才能评论
关注微信