3 回答

TA贡献1804条经验 获得超2个赞
使用map和fillna:
df1['id'] = df1['id'].map(df2.set_index('id')['token']).fillna(df1['id'])
df1
输出:
id first last size
0 ZA.00 1978-01-01 1979-01-01 2
1 As.11 2000-01-01 2000-01-01 1
2 SD.34 1998-01-01 2000-01-01 3
3 D 1998-01-01 1998-01-01 1
4 E 1999-01-01 2000-01-01 2
您可以使用map系列作为参数。

TA贡献1824条经验 获得超8个赞
使用Merge和combine_first:
df = df1.merge(df2,how='outer')
df['id'] = df['token'].combine_first(df['id'] )
df.drop('token',inplace=True,axis=1)
另一种方法是replace与字典一起使用df2.values,这里 df1 数据框更改。:
df1.id.replace(dict(df2.values),inplace=True)
id first last size
0 ZA.00 1978-01-01 1979-01-01 2
1 As.11 2000-01-01 2000-01-01 1
2 SD.34 1998-01-01 2000-01-01 3
3 D 1998-01-01 1998-01-01 1
4 E 1999-01-01 2000-01-01 2
添加回答
举报