首页 后端开发 Python教程 如何在保留主数据帧中的信息的同时合并列上的数据帧?

如何在保留主数据帧中的信息的同时合并列上的数据帧?

Oct 30, 2024 am 09:42 AM

How to Merge DataFrames on a Column While Preserving Information from the Primary DataFrame?

在保留信息的同时合并列上的 DataFrame

使用 Pandas 在 Python 中处理数据时,基于公共列合并数据帧是一种常见的做法任务。然而,有时有必要保留两个数据帧中的信息,特别是当它们包含重叠但不完整的数据时。本文探讨了一种在列上合并数据帧的解决方案,同时确保保留主数据帧中的信息。

问题陈述

考虑两个数据帧,df1 和 df2。 df1 包含有关个人年龄的信息,而 df2 包含其性别信息。目标是在“名称”列上合并 df1 和 df2,但仅保留 df1 中的信息。个体可能并不总是出现在两个数据框中。

解决方案

为了实现这一点,我们可以使用通过设置索引创建的Series的map()方法将一个数据帧添加到我们要合并的列。 map() 方法允许我们应用映射函数,在本例中,该函数将在另一个数据帧中进行查找。

<code class="python"># Create the dataframes
df1 = pd.DataFrame({'Name': ['Tom', 'Sara', 'Eva', 'Jack', 'Laura'],
                    'Age': [34, 18, 44, 27, 30]})

df2 = pd.DataFrame({'Name': ['Tom', 'Paul', 'Eva', 'Jack', 'Michelle'],
                    'Sex': ['M', 'M', 'F', 'M', 'F']})

# Set the index of df2 to Name
df2.set_index('Name', inplace=True)

# Perform the lookup using map
df1['Sex'] = df1['Name'].map(df2['Sex'])

# Display the merged dataframe
print(df1)</code>
登录后复制

替代解决方案:Left Join

或者,我们可以使用带有左连接的合并,这确保 df1 中的所有行都包含在合并的数据框中,即使 df2 中没有相应的行。

<code class="python"># Perform the left join
df3 = df1.merge(df2, on='Name', how='left')

# Display the merged dataframe
print(df3)</code>
登录后复制

注意: 如果数据框包含多个要合并的列,请使用 merge(on=['Year', 'Code'], how='left') 或指定左合并后的列(例如 df1.merge( df2[['Year', 'Code', 'Val']], on=['Year', 'Code'], how='left')).

处理重复

如果用于合并的列有重复项,则处理重复值以防止歧义非常重要。这可以使用 drop_duplicates() 或使用字典来指定映射来完成。

以上是如何在保留主数据帧中的信息的同时合并列上的数据帧?的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何使用Python查找文本文件的ZIPF分布 如何使用Python查找文本文件的ZIPF分布 Mar 05, 2025 am 09:58 AM

如何使用Python查找文本文件的ZIPF分布

如何在Python中下载文件 如何在Python中下载文件 Mar 01, 2025 am 10:03 AM

如何在Python中下载文件

python中的图像过滤 python中的图像过滤 Mar 03, 2025 am 09:44 AM

python中的图像过滤

我如何使用美丽的汤来解析HTML? 我如何使用美丽的汤来解析HTML? Mar 10, 2025 pm 06:54 PM

我如何使用美丽的汤来解析HTML?

如何使用Python使用PDF文档 如何使用Python使用PDF文档 Mar 02, 2025 am 09:54 AM

如何使用Python使用PDF文档

如何在django应用程序中使用redis缓存 如何在django应用程序中使用redis缓存 Mar 02, 2025 am 10:10 AM

如何在django应用程序中使用redis缓存

引入自然语言工具包(NLTK) 引入自然语言工具包(NLTK) Mar 01, 2025 am 10:05 AM

引入自然语言工具包(NLTK)

如何使用TensorFlow或Pytorch进行深度学习? 如何使用TensorFlow或Pytorch进行深度学习? Mar 10, 2025 pm 06:52 PM

如何使用TensorFlow或Pytorch进行深度学习?

See all articles