gpt4 book ai didi

python - pandas fillna 按顺序一步一步

转载 作者:行者123 更新时间:2023-12-05 03:24:20 34 4
gpt4 key购买 nike

我有如下数据框

Re_MC,Fi_MC,Fin_id,Res_id,     
1,2,3,4
,7,6,11
11,,31,32
,,35,38

df1 = pd.read_clipboard(sep=',')

我想根据两个步骤fillna

a) 首先,只比较Re_MCFi_MC。如果其中任一列中缺少某个值,请从另一列中复制它。

b) 尽管执行了步骤 a,如果 Re_MCFi_MC 仍然存在 NA,则从 Fin_id 中复制 的值Fi_MCRes_id 用于 Re_MC

所以,我尝试了以下两种方法

方法 1 - 这可行但不高效/优雅

df1['Re_MC'] = df1['Re_MC'].fillna(df1['Fi_MC'])
df1['Fi_MC'] = df1['Fi_MC'].fillna(df1['Re_MC'])
df1['Re_MC'] = df1['Re_MC'].fillna(df1['Res_id'])
df1['Fi_MC'] = df1['Fi_MC'].fillna(df1['Fin_id'])

方法 2 - 这不起作用并提供不正确的输出

df1['Re_MC'] = df1['Re_MC'].fillna(df1['Fi_MC']).fillna(df1['Res_id'])
df1['Fi_MC'] = df1['Fi_MC'].fillna(df1['Re_MC']).fillna(df1['Fin_id'])

有没有其他有效的方式来按顺序填写na?意思是,我们先执行 step a,然后根据 step a 的结果执行 step b

我希望我的输出如下所示

enter image description here

更新代码

df_new = (df_new 
.fillna({'Re MC': df_new['Re Cust'],'Re MC': df_new['Re Cust_System']})
.fillna({'Fi MC' : df_new['Fi.Fi Customer'],'Final MC':df_new['Re.Fi Customer']})
.fillna({'Fi MC' : df_new['Re MC']})
.fillna({'Class Fi MC':df_new['Re MC']})
)

最佳答案

您可以在 fillna 中使用字典:

(df1
.fillna({'Re_MC': df1['Fi_MC'], 'Fi_MC': df1['Re_MC']})
.fillna({'Re_MC': df1['Res_id'], 'Fi_MC': df1['Fin_id']})
)

输出:

   Re_MC  Fi_MC  Fin_id  Res_id
0 1.0 2.0 3 4
1 7.0 7.0 6 11
2 11.0 11.0 31 32
3 38.0 35.0 35 38

关于python - pandas fillna 按顺序一步一步,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/72314386/

34 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com