京公网安备 11010802034615号
经营许可证编号:京B2-20210330
在pandas中,有多种方法可以合并和拼接数据。常见的方法包括append()、concat()、merge()。
append()函数用于将一个DataFrame或Series对象追加到另一个DataFrame中。
import pandas as pd
df1 = pd.DataFrame({'A': ['a', 'b'],
'B': [1, 2]})
df1
| A | B | |
|---|---|---|
| 0 | a | 1 |
| 1 | b | 2 |
df2 = pd.DataFrame({'A': [ 'b', 'c','d'],
'B': [2, 3, 4]})
df2
| A | B | |
|---|---|---|
| 0 | b | 2 |
| 1 | c | 3 |
| 2 | d | 4 |
df1.append(df2,ignore_index=True)
| A | B | |
|---|---|---|
| 0 | a | 1 |
| 1 | b | 2 |
| 2 | b | 2 |
| 3 | c | 3 |
| 4 | d | 4 |
concat()函数用于沿指定轴将多个对象(比如Series、DataFrame)堆叠在一起。可以沿行或列方向进行拼接。
先看一个上下堆叠的例子
df1 = pd.DataFrame({'A': ['a', 'b'],
'B': [1, 2]})
df1
| A | B | |
|---|---|---|
| 0 | a | 1 |
| 1 | b | 2 |
df2 = pd.DataFrame({'A': [ 'b', 'c','d'],
'B': [2, 3, 4]})
df2
| A | B | |
|---|---|---|
| 0 | b | 2 |
| 1 | c | 3 |
| 2 | d | 4 |
pd.concat([df1,df2],axis =0) # 上下拼接
| A | B | |
|---|---|---|
| 0 | a | 1 |
| 1 | b | 2 |
| 0 | b | 2 |
| 1 | c | 3 |
| 2 | d | 4 |
再看一个左右堆叠的例子
df1 = pd.DataFrame({'A': ['a', 'b']})
df1
| A | |
|---|---|
| 0 | a |
| 1 | b |
df2 = pd.DataFrame({'B': [1, 2],
'C': [2, 4]})
df2
| B | C | |
|---|---|---|
| 0 | 1 | 2 |
| 1 | 2 | 4 |
pd.concat([df1,df2],axis =1) # 左右拼接
| A | B | C | |
|---|---|---|---|
| 0 | a | 1 | 2 |
| 1 | b | 2 | 4 |
merge()函数用于根据一个或多个键将两个DataFrame的行连接起来。类似于SQL中的JOIN操作。

先看一下 inner 和 outer连接
df1 = pd.DataFrame({'A': ['a', 'b', 'c'],
'B': [1, 2, 3]})
df1
| A | B | |
|---|---|---|
| 0 | a | 1 |
| 1 | b | 2 |
| 2 | c | 3 |
df2 = pd.DataFrame({'A': [ 'b', 'c','d'],
'B': [2, 3, 4]})
df2
| A | B | |
|---|---|---|
| 0 | b | 2 |
| 1 | c | 3 |
| 2 | d | 4 |
pd.merge(df1,df2,how = 'inner')
| A | B | |
|---|---|---|
| 0 | b | 2 |
| 1 | c | 3 |
pd.merge(df1,df2,how = 'outer')
| A | B | |
|---|---|---|
| 0 | a | 1 |
| 1 | b | 2 |
| 2 | c | 3 |
| 3 | d | 4 |
再看左右链接的例子:
df1 = pd.DataFrame({'A': ['a', 'b', 'c'],
'B': [1, 2, 3]})
df1
| A | B | |
|---|---|---|
| 0 | a | 1 |
| 1 | b | 2 |
| 2 | c | 3 |
df2 = pd.DataFrame({'A': [ 'b', 'c','d'],
'C': [2, 3, 4]})
df2
| A | C | |
|---|---|---|
| 0 | b | 2 |
| 1 | c | 3 |
| 2 | d | 4 |
pd.merge(df1,df2,how = 'left',on = "A") # 左连接
| A | B | C | |
|---|---|---|---|
| 0 | a | 1 | NaN |
| 1 | b | 2 | 2.0 |
| 2 | c | 3 | 3.0 |
pd.merge(df1,df2,how = 'right',on = "A") # 右连接
| A | B | C | |
|---|---|---|---|
| 0 | b | 2.0 | 2 |
| 1 | c | 3.0 | 3 |
| 2 | d | NaN | 4 |
pd.merge(df1,df2,how = 'inner',on = "A") # 内连接
| A | B | C | |
|---|---|---|---|
| 0 | b | 2 | 2 |
| 1 | c | 3 | 3 |
pd.merge(df1,df2,how = 'outer',on = "A") # 外连接
| A | B | C | |
|---|---|---|---|
| 0 | a | 1.0 | NaN |
| 1 | b | 2.0 | 2.0 |
| 2 | c | 3.0 | 3.0 |
| 3 | d | NaN | 4.0 |
补充1个小技巧
df1[df1['A'].isin(df2['A'])] # 返回在df1中列'A'的值在df2中也存在的行
| A | B | |
|---|---|---|
| 1 | b | 2 |
| 2 | c | 3 |
df1[~df1['A'].isin(df2['A'])] # 返回在df1中列'A'的值在df2中不存在的行
| A | B | |
|---|---|---|
| 0 | a | 1 |
数据分析咨询请扫描二维码
若不方便扫码,搜微信号:CDAshujufenxi
在数据驱动业务的实践中,CDA(Certified Data Analyst)数据分析师的核心工作,本质上是通过“指标”这一数据语言,解读业务现 ...
2025-12-25在金融行业的数字化转型进程中,SQL作为数据处理与分析的核心工具,贯穿于零售银行、证券交易、保险理赔、支付结算等全业务链条 ...
2025-12-24在数据分析领域,假设检验是验证“数据差异是否显著”的核心工具,而独立样本t检验与卡方检验则是其中最常用的两种方法。很多初 ...
2025-12-24在企业数字化转型的深水区,数据已成为核心生产要素,而“让数据可用、好用”则是挖掘数据价值的前提。对CDA(Certified Data An ...
2025-12-24数据分析师认证考试全面升级后,除了考试场次和报名时间,小伙伴们最关心的就是报名费了,报 ...
2025-12-23CDA中国官网是全国统一的数据分析师认证报名网站,由认证考试委员会与持证人会员、企业会员以及行业知名第三方机构共同合作,致 ...
2025-12-23在Power BI数据可视化分析中,矩阵是多维度数据汇总的核心工具,而“动态计算平均值”则是矩阵分析的高频需求——无论是按类别计 ...
2025-12-23在SQL数据分析场景中,“日期转期间”是高频核心需求——无论是按日、周、月、季度还是年度统计数据,都需要将原始的日期/时间字 ...
2025-12-23在数据驱动决策的浪潮中,CDA(Certified Data Analyst)数据分析师的核心价值,早已超越“整理数据、输出报表”的基础层面,转 ...
2025-12-23在使用Excel数据透视表进行数据分析时,我们常需要在透视表旁添加备注列,用于标注数据背景、异常说明、业务解读等关键信息。但 ...
2025-12-22在MySQL数据库的性能优化体系中,索引是提升查询效率的“核心武器”——一个合理的索引能将百万级数据的查询耗时从秒级压缩至毫 ...
2025-12-22在数据量爆炸式增长的数字化时代,企业数据呈现“来源杂、格式多、价值不均”的特点,不少CDA(Certified Data Analyst)数据分 ...
2025-12-22在企业数据化运营体系中,同比、环比分析是洞察业务趋势、评估运营效果的核心手段。同比(与上年同期对比)可消除季节性波动影响 ...
2025-12-19在数字化时代,用户已成为企业竞争的核心资产,而“理解用户”则是激活这一资产的关键。用户行为分析系统(User Behavior Analys ...
2025-12-19在数字化转型的深水区,企业对数据价值的挖掘不再局限于零散的分析项目,而是转向“体系化运营”——数据治理体系作为保障数据全 ...
2025-12-19在数据科学的工具箱中,析因分析(Factor Analysis, FA)、聚类分析(Clustering Analysis)与主成分分析(Principal Component ...
2025-12-18自2017年《Attention Is All You Need》一文问世以来,Transformer模型凭借自注意力机制的强大建模能力,在NLP、CV、语音等领域 ...
2025-12-18在CDA(Certified Data Analyst)数据分析师的时间序列分析工作中,常面临这样的困惑:某电商平台月度销售额增长20%,但增长是来 ...
2025-12-18在机器学习实践中,“超小数据集”(通常指样本量从几十到几百,远小于模型参数规模)是绕不开的场景——医疗领域的罕见病数据、 ...
2025-12-17数据仓库作为企业决策分析的“数据中枢”,其价值完全依赖于数据质量——若输入的是缺失、重复、不一致的“脏数据”,后续的建模 ...
2025-12-17