[英]Pandas: Merge values from one dataframe to another based on condition
[英]substitue values of one dataframe from values of another dataframe based on condition
我有一個 df 看起來像
floor id p1 p2 p3
L1 1 5 6 7
L1 2 5 8 3
L2 1 4 2 1
L2 2 4 5 4
和 df2
floor id p1 p2 p4
L1 1 6 6 5
L1 2 9 8 5
L2 1 5 5 5
L2 2 4 5 5
如何將特定樓層和 id 的 df 中 p1 和 p2 的值替換為 df2 中相應值的值?
我們也可以使用DataFrame.merge
df1 = (df1[df1.columns.difference(['p1','p2'])].merge(df2,
on =['floor','id'],
how ='left')
.fillna(df1)[df1.columns])
print(df1)
floor id p1 p2 p3
0 L1 1 6 6 7
1 L1 2 9 8 3
2 L2 1 5 5 1
3 L2 2 4 5 4
Merge 可用於此特定問題:
# left join
df = (df.merge(df2, left_on=['floor', 'id'], how='left', right_on=['floor', 'id'])
# fill missing values with corresponding original df values
df['p1_y'] = df['p1_y'].fillna(df['p1_x']).astype(int)
df['p2_y'] = df['p2_y'].fillna(df['p2_x']).astype(int)
# drop unnecessary columns
df.drop(['p1_x', 'p2_x', 'p4'], axis=1, inplace=True)
df.rename(columns={'p1_y': 'p1', 'p2_y': 'p2'}, inplace=True)
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.