作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有如下数据框
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_MC
和Fi_MC
。如果其中任一列中缺少某个值,请从另一列中复制它。
b) 尽管执行了步骤 a,如果 Re_MC
或 Fi_MC
仍然存在 NA,则从 Fin_id
中复制 的值Fi_MC
和 Res_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
我希望我的输出如下所示
更新代码
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/
我是一名优秀的程序员,十分优秀!