打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
在DataFrame中新建列赋值后全部为NaN的问题释疑

       在pandas中,有时候我们对一个df以如下方式新创建一个列,然后用一个Series赋值给新建的列,但是发现得到的新列的值全部为NaN,这是什么原因呢?

df['newColumn']=df_other['otherColumn']

       注意以上赋值方式中,等号右边为一个Series,这时就需要考虑这个Series的index和df的index是否一致,如果不一致,那么就会造成在不一致的索引上的值全部为NaN,所以这个问题就是由Series赋值,索引不一致造成的。因为Series本身就带有索引,赋值时,还会同时按顺序进行两者的索引匹配,只有索引匹配上的行才会成功赋值,而没有匹配上的就会为NaN。

       当我们不想要这种匹配,只想直接把df_other['otherColumn']的值赋给df['newColumn']时,只需去掉索引即可,可以通过list(df_other['otherColumn'])或者df_other['otherColumn'].values等方式进行转化,这样就可以避免这个问题。

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
pandas小记:pandas索引和选择
Python 数据分析包:pandas 基础
《Python数据分析常用手册》一、NumPy和Pandas篇
教你如何用50道练习打通Pandas
Python数据分析——Pandas数据结构和操作
Python学习笔记
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服