Pandas合并数据帧与按值建列技巧
时间:2025-10-21 19:03:37 278浏览 收藏
在IT行业这个发展更新速度很快的行业,只有不停止的学习,才不会被行业所淘汰。如果你是文章学习者,那么本文《Pandas 合并数据帧与按值建列教程》就很适合你!本篇内容主要包括##content_title##,希望对大家的知识积累有所帮助,助力实战开发!

本文旨在提供一个清晰、简洁的指南,介绍如何使用 Pandas 合并两个数据帧,并基于特定列的值创建新的列。我们将通过一个具体的例子,演示如何将两个包含 ZIP 代码、区域和分段信息的数据帧合并,并根据分段类型生成新的区域列。
Pandas 库提供了强大的数据处理功能,其中数据帧的合并是常见的操作之一。本教程将重点介绍如何合并两个数据帧,并根据特定列的值创建新的列,以满足特定的数据分析需求。我们将以一个实际案例出发,讲解如何利用 merge() 函数实现这一目标。
数据准备
首先,我们需要准备两个数据帧 df_1 和 df_2,它们都包含 ZIP、TERRITORY 和 SEGMENT 列。df_1 包含 CR1 分段的数据,而 df_2 包含 CR2 分段的数据。
import pandas as pd
df_1 = pd.DataFrame({
'ZIP': [93517, 31625, 89311],
'TERRITORY': [1001, 1002, 1002],
'SEGMENT': ['CR1', 'CR1', 'CR1']
})
df_2 = pd.DataFrame({
'ZIP': [93517, 31625, 72844],
'TERRITORY': [2001, 2002, 2003],
'SEGMENT': ['CR2', 'CR2', 'CR2']
})
print("df_1:\n", df_1)
print("\ndf_2:\n", df_2)数据帧合并与列创建
我们的目标是将这两个数据帧合并成一个新的数据帧 df_final,其中包含 ZIP 列,以及根据 SEGMENT 值创建的 CR1_TERRITORY 和 CR2_TERRITORY 列。
可以使用 Pandas 的 merge() 函数来实现这个目标。merge() 函数允许我们根据一个或多个公共列合并两个数据帧。在本例中,我们将使用 ZIP 列作为公共列,并使用 how='outer' 参数进行外连接,以保留两个数据帧中的所有行。suffix 参数用于区分两个数据帧中同名的列。
df_final = df_1.merge(df_2, how='outer', on='ZIP', suffixes=['_CR1', '_CR2'])
print("\nMerged df_final:\n", df_final)处理缺失值
由于外连接会保留两个数据帧中的所有行,因此 df_final 中可能会出现缺失值(NaN)。我们需要将这些缺失值替换为 0。
df_final['TERRITORY_CR1'] = df_final['TERRITORY_CR1'].fillna(0)
df_final['TERRITORY_CR2'] = df_final['TERRITORY_CR2'].fillna(0)
print("\ndf_final with filled NaN:\n", df_final)重命名列
为了使列名更清晰,我们可以重命名 TERRITORY_CR1 和 TERRITORY_CR2 列为 CR1_TERRITORY 和 CR2_TERRITORY。
df_final = df_final.rename(columns={'TERRITORY_CR1': 'CR1_TERRITORY', 'TERRITORY_CR2': 'CR2_TERRITORY'})
print("\ndf_final with renamed columns:\n", df_final)选择需要的列
最后,我们只保留 ZIP、CR1_TERRITORY 和 CR2_TERRITORY 列。
df_final = df_final[['ZIP', 'CR1_TERRITORY', 'CR2_TERRITORY']]
print("\nFinal df_final:\n", df_final)完整代码示例
import pandas as pd
df_1 = pd.DataFrame({
'ZIP': [93517, 31625, 89311],
'TERRITORY': [1001, 1002, 1002],
'SEGMENT': ['CR1', 'CR1', 'CR1']
})
df_2 = pd.DataFrame({
'ZIP': [93517, 31625, 72844],
'TERRITORY': [2001, 2002, 2003],
'SEGMENT': ['CR2', 'CR2', 'CR2']
})
df_final = df_1.merge(df_2, how='outer', on='ZIP', suffixes=['_CR1', '_CR2'])
df_final['CR1_TERRITORY'] = df_final['TERRITORY_CR1'].fillna(0)
df_final['CR2_TERRITORY'] = df_final['TERRITORY_CR2'].fillna(0)
df_final = df_final[['ZIP', 'CR1_TERRITORY', 'CR2_TERRITORY']]
print(df_final)总结与注意事项
- merge() 函数是 Pandas 中合并数据帧的强大工具。
- how 参数控制合并的方式,常用的有 inner、outer、left 和 right。
- on 参数指定用于合并的公共列。
- suffixes 参数用于区分两个数据帧中同名的列。
- 在合并后,可能需要处理缺失值。
- 根据实际需求,可以选择需要的列。
本教程提供了一个使用 Pandas 合并数据帧并基于值创建列的示例。通过理解 merge() 函数的用法和掌握数据处理的技巧,可以灵活地应对各种数据分析任务。希望本教程能够帮助你更好地使用 Pandas 进行数据处理。
终于介绍完啦!小伙伴们,这篇关于《Pandas合并数据帧与按值建列技巧》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
296 收藏
-
351 收藏
-
157 收藏
-
485 收藏
-
283 收藏
-
349 收藏
-
291 收藏
-
204 收藏
-
401 收藏
-
227 收藏
-
400 收藏
-
327 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习