pandas库学习之merge函数

pandas库学习之merge函数

一、简介

pandas.merge函数用于合并两个DataFrame对象。它根据一个或多个键将两个DataFrame对象连接在一起,类似于SQL中的JOIN操作。

二、语法和参数

python 复制代码
pandas.merge(left, right, how='inner', on=None, left_on=None, right_on=None, left_index=False, right_index=False, sort=False, suffixes=('_x', '_y'), copy=True, indicator=False, validate=None)
参数:
  • left:第一个要合并的DataFrame对象。⭐
  • right:第二个要合并的DataFrame对象。⭐
  • how :字符串,默认值为inner,表示连接类型。可选值有leftrightouterinner。⭐
  • on :列名或列名的列表,表示用于连接的列。必须存在于左右两个DataFrame中。⭐
  • left_on:左侧DataFrame中用于连接的列名或索引级别。
  • right_on:右侧DataFrame中用于连接的列名或索引级别。
  • left_index:布尔值,表示是否使用左侧DataFrame的索引进行连接。
  • right_index:布尔值,表示是否使用右侧DataFrame的索引进行连接。
  • sort:布尔值,表示是否按连接键对结果进行排序。默认值为False。
  • suffixes :字符串元组,表示重复列名的后缀,默认值为(_x, _y)。
  • copy:布尔值,默认值为True,表示是否在合并数据时始终复制数据。
  • indicator:布尔值或字符串,表示是否添加一列指示每个行的来源。
  • validate :字符串,用于验证合并的类型。可选值有one_to_oneone_to_manymany_to_onemany_to_many

三、实例

3.1 内连接
python 复制代码
import pandas as pd

df1 = pd.DataFrame({
    'key': ['A', 'B', 'C', 'D'],
    'value1': [1, 2, 3, 4]
})

df2 = pd.DataFrame({
    'key': ['B', 'D', 'E', 'F'],
    'value2': [5, 6, 7, 8]
})

merged_df = pd.merge(df1, df2, on='key', how='inner')

print(merged_df)

输出:

  key  value1  value2
0   B       2       5
1   D       4       6
3.2 左连接
python 复制代码
import pandas as pd

df1 = pd.DataFrame({
    'key': ['A', 'B', 'C', 'D'],
    'value1': [1, 2, 3, 4]
})

df2 = pd.DataFrame({
    'key': ['B', 'D', 'E', 'F'],
    'value2': [5, 6, 7, 8]
})

merged_df = pd.merge(df1, df2, on='key', how='left')

print(merged_df)

输出:

  key  value1  value2
0   A       1     NaN
1   B       2     5.0
2   C       3     NaN
3   D       4     6.0
3.3 外连接
python 复制代码
import pandas as pd

df1 = pd.DataFrame({
    'key': ['A', 'B', 'C', 'D'],
    'value1': [1, 2, 3, 4]
})

df2 = pd.DataFrame({
    'key': ['B', 'D', 'E', 'F'],
    'value2': [5, 6, 7, 8]
})

merged_df = pd.merge(df1, df2, on='key', how='outer')

print(merged_df)

输出

  key  value1  value2
0   A     1.0     NaN
1   B     2.0     5.0
2   C     3.0     NaN
3   D     4.0     6.0
4   E     NaN     7.0
5   F     NaN     8.0

四、注意事项

  1. 确保用于连接的键在两个DataFrame中都存在,否则结果会不如预期。
  2. 连接类型(如innerouterleftright)决定了合并结果的形状和内容。选择适当的连接类型非常重要。
  3. 使用suffixes参数可以避免在连接时因列名冲突而导致的问题。
  4. 如果需要使用索引进行连接,可以将left_indexright_index设置为True。
  5. validate参数可以用来检查合并的逻辑是否正确,确保数据的一致性。
相关推荐
WZF-Sang27 分钟前
Linux权限理解【Shell的理解】【linux权限的概念、管理、切换】【粘滞位理解】
linux·运维·服务器·开发语言·学习
狂飙的张兴发1 小时前
认知小文2《成功之路:习惯、学习与实践》
学习·考研·职场和发展·跳槽·学习方法·改行学it·高考
你可以自己看1 小时前
python的基础语法
开发语言·python
爱编程的小新☆1 小时前
C语言内存函数
c语言·开发语言·学习
夜清寒风2 小时前
opencv学习:图像掩码处理和直方图分析及完整代码
人工智能·opencv·学习·算法·机器学习·计算机视觉
akhfuiigabv3 小时前
使用Neo4j-Cypher-FT实现自然语言查询图数据库
数据库·python·oracle·neo4j
吃着火锅x唱着歌3 小时前
Go语言设计与实现 学习笔记 第七章 内存管理(1)
笔记·学习·golang
繁依Fanyi3 小时前
828华为云征文|华为Flexus云服务器搭建OnlyOffice私有化在线办公套件
服务器·开发语言·前端·python·算法·华为·华为云
zhangfeng11333 小时前
在 PyTorch 中,除了 pad_sequence 还有哪些其他处理序列数据的函数?时间序列数据 预处理
人工智能·pytorch·python·深度学习
我命由我123453 小时前
2.使用 VSCode 过程中的英语积累 - Edit 菜单(每一次重点积累 5 个单词)
前端·javascript·ide·vscode·学习·编辑器·学习方法