pandas中merge用于基于键的关系型连接,如SQL的JOIN,适合通过共同列或索引关联数据;concat则用于沿轴堆叠DataFrame,类似UNION ALL,适用于简单拼接。选择merge当需根据逻辑关系(如客户ID)整合数据,选择concat当需直接堆叠行或列。其他方法如join、combine_first等在特定场景下补充使用。

在Pandas中,合并两个DataFrame主要通过
merge
concat
merge
concat
解决方案
pandas.merge
import pandas as pd
# 示例数据
df1 = pd.DataFrame({
'id': [1, 2, 3, 4],
'name': ['Alice', 'Bob', 'Charlie', 'David'],
'city': ['NY', 'LA', 'SF', 'NY']
})
df2 = pd.DataFrame({
'id': [1, 2, 5, 3],
'salary': [70000, 80000, 90000, 75000],
'department': ['HR', 'IT', 'Finance', 'HR']
})
# 内连接 (inner merge): 仅保留两个DataFrame中'id'列都有的行
merged_df_inner = pd.merge(df1, df2, on='id', how='inner')
# print("内连接结果:\n", merged_df_inner)
# 左连接 (left merge): 保留左DataFrame的所有行,匹配右DataFrame的行;右DataFrame不匹配的用NaN填充
merged_df_left = pd.merge(df1, df2, on='id', how='left')
# print("\n左连接结果:\n", merged_df_left)
# 右连接 (right merge): 保留右DataFrame的所有行,匹配左DataFrame的行;左DataFrame不匹配的用NaN填充
merged_df_right = pd.merge(df1, df2, on='id', how='right')
# print("\n右连接结果:\n", merged_df_right)
# 外连接 (outer merge): 保留两个DataFrame的所有行,不匹配的用NaN填充
merged_df_outer = pd.merge(df1, df2, on='id', how='outer')
# print("\n外连接结果:\n", merged_df_outer)
# 基于多个键合并
df3 = pd.DataFrame({
'first_name': ['Alice', 'Bob'],
'last_name': ['Smith', 'Johnson'],
'age': [30, 24]
})
df4 = pd.DataFrame({
'first_name': ['Alice', 'Bob'],
'last_name': ['Smith', 'Johnson'],
'occupation': ['Engineer', 'Designer']
})
merged_multi_key = pd.merge(df3, df4, on=['first_name', 'last_name'])
# print("\n多键合并结果:\n", merged_multi_key)
# 基于索引合并
df5 = pd.DataFrame({'value1': [10, 20]}, index=['A', 'B'])
df6 = pd.DataFrame({'value2': [30, 40]}, index=['B', 'C'])
merged_on_index = pd.merge(df5, df6, left_index=True, right_index=True, how='outer')
# print("\n基于索引合并结果:\n", merged_on_index)pandas.concat
立即学习“Python免费学习笔记(深入)”;
import pandas as pd
# 示例数据
df_a = pd.DataFrame({
'col1': [1, 2],
'col2': ['A', 'B']
})
df_b = pd.DataFrame({
'col1': [3, 4],
'col2': ['C', 'D']
})
df_c = pd.DataFrame({
'col3': [5, 6],
'col4': ['E', 'F']
})
# 沿行方向拼接 (axis=0, 默认行为)
concatenated_rows = pd.concat([df_a, df_b])
# print("沿行方向拼接结果:\n", concatenated_rows)
# 沿行方向拼接并重置索引
concatenated_rows_reset_index = pd.concat([df_a, df_b], ignore_index=True)
# print("\n沿行方向拼接并重置索引结果:\n", concatenated_rows_reset_index)
# 沿列方向拼接 (axis=1)
concatenated_cols = pd.concat([df_a, df_c], axis=1)
# print("\n沿列方向拼接结果:\n", concatenated_cols)
# 沿列方向拼接,即使索引不完全匹配
df_d = pd.DataFrame({'col_x': [10, 20]}, index=[0, 2])
df_e = pd.DataFrame({'col_y': [30, 40]}, index=[0, 1])
concatenated_cols_mismatch_index = pd.concat([df_d, df_e], axis=1)
# print("\n沿列方向拼接,索引不匹配:\n", concatenated_cols_mismatch_index)
# 使用keys参数为每个DataFrame添加一个层级索引
concatenated_with_keys = pd.concat([df_a, df_b], keys=['group_a', 'group_b'])
# print("\n使用keys参数拼接结果:\n", concatenated_with_keys)pandas.merge
concat
这是一个非常关键的问题,因为选择错误可能会导致数据分析结果出现偏差。从我的经验来看,当你需要基于数据之间的“逻辑关系”来组合它们时,
merge
merge
merge
on
left_index
right_index
how
inner
left
right
outer
例如,如果你想:
总的来说,当你的数据结构是“宽”的,并且你希望通过一个或多个共同的标识符来扩展或聚合现有数据时,
merge
concat
pandas.concat
concat
常见陷阱:
concat
axis=0
0, 1, 2
0, 1, 2
concat
outer
NaN
join='inner'
concat
concat
最佳实践:
ignore_index=True
concat
ignore_index=True
# 避免索引重复的最佳实践 df_combined = pd.concat([df_a, df_b], ignore_index=True)
join='inner'
join='inner'
NaN
# 只保留共同列的最佳实践 df_combined_inner_cols = pd.concat([df_a, df_with_different_cols], join='inner')
keys
keys
# 保留来源信息的最佳实践 df_with_source_info = pd.concat([df_a, df_b], keys=['source_A', 'source_B']) # df_with_source_info.loc['source_A'] 可以访问来自df_a的数据
concat
.astype()
concat
merge
concat
当然,Pandas提供了不止
merge
concat
.join()
DataFrame.join()
merge
how='left'
join
df_left = pd.DataFrame({'value_a': [1, 2]}, index=['A', 'B'])
df_right = pd.DataFrame({'value_b': [3, 4]}, index=['B', 'C'])
joined_df = df_left.join(df_right, how='outer') # 默认是left,这里演示outer
# print(joined_df)它在内部其实还是调用了
merge
join
.append()
concat
DataFrame.append()
pd.concat([df1, df2], axis=0)
# df_a.append(df_b, ignore_index=True) # 旧用法,现在会发出警告 # 推荐使用: # pd.concat([df_a, df_b], ignore_index=True)
从Pandas 1.4版本开始,
append()
pd.concat()
concat
.combine()
.combine_first()
.combine()
df_x = pd.DataFrame({'A': [1, 2], 'B': [3, 4]})
df_y = pd.DataFrame({'A': [5, 6], 'B': [7, 8]})
combined_max = df_x.combine(df_y, lambda s1, s2: s1 if s1 > s2 else s2)
# print(combined_max) # 会在每个位置选择较大的值.combine_first()
df_main = pd.DataFrame({'A': [1, np.nan], 'B': [3, 4]})
df_backup = pd.DataFrame({'A': [5, 6], 'B': [7, np.nan]})
filled_df = df_main.combine_first(df_backup)
# print(filled_df) # df_main中的NaN会被df_backup的对应值填充这两个方法更侧重于数据的“填充”或“合并策略”,而不是基于键的结构化连接。它们在数据清洗和预处理阶段能发挥独特的作用。
选择哪种方法,归根结底还是要看你数据的结构、你希望达到的结果,以及你对性能和代码可读性的考量。熟练掌握这些工具,能让你在数据处理的道路上更加游刃有余。
以上就是python pandas如何合并两个dataframe_pandas merge与concat合并数据框方法的详细内容,更多请关注php中文网其它相关文章!
python怎么学习?python怎么入门?python在哪学?python怎么学才快?不用担心,这里为大家提供了python速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号