如何基于共享列组合 Pandas DataFrame:'join()”和'merge()”指南

Barbara Streisand
发布: 2024-10-24 22:10:02
原创
173 人浏览过

How to Combine Pandas DataFrames Based on a Shared Column: A Guide to `join()` and `merge()`

在共享列上组合 Pandas 数据框:综合指南

简介

组合来自多个数据框的数据是数据分析中的常见任务。 Pandas 提供了多种方法来实现这一点,包括 join() 和 merge() 函数。本文演示了如何使用这些函数来组合共享公共列的两个数据框。

使用 join() 函数

join() 函数默认执行内连接,这意味着它只保留在连接列中具有匹配值的行。在提供的示例中,无法使用 join() 函数,因为 Restaurant_ids_dataframe 和 Restaurant_review_frame 具有重叠的列名称(星号和类型),如错误消息所示:

Exception: columns overlap: Index([business_id, stars, type], dtype=object)
登录后复制

使用 merge() 函数

merge() 函数为组合数据帧提供了更大的灵活性。要执行外连接(保留两个数据帧中的所有行),请使用 how='outer' 参数:

<code class="python">import pandas as pd
pd.merge(restaurant_ids_dataframe, restaurant_review_frame, on='business_id', how='outer')</code>
登录后复制

默认情况下,merge() 使用后缀 ('_x', '_y' ) 来区分具有重复名称的列。要自定义后缀,请将值传递给 suffixes 参数,如下所示:

<code class="python">pd.merge(restaurant_ids_dataframe, restaurant_review_frame, on='business_id', how='outer', suffixes=('_restaurant_id', '_restaurant_review'))</code>
登录后复制

结论

join() 和 merge() 函数都可以用于组合数据框在公共列上。了解这些函数之间的差异对于实现所需的连接行为至关重要。 merge() 函数提供了更大的灵活性,包括执行外部联接和自定义列后缀的能力。通过掌握这些技术,您可以有效地组合数据帧,从数据集中提取有意义的见解。

以上是如何基于共享列组合 Pandas DataFrame:'join()”和'merge()”指南的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:php.cn
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!