而df.fillna(0)用0填充所有NA / NaN值,是否有一个函数将所有非NA / NaN值替换为另一个值,例如1?
如果我的DataFrame中的值是可变长度列表,那么:
> df.replace()要求列表长度相同
>布尔索引,如df [len(df)> 0] = 1抛出ValueError:无法插入True,已经存在
> pandas.get_dummies()抛出TypeError:unhashable类型:’list’
有更简单的解决方案吗?
解决方法:
您可以使用df [df.notnull()] = 1进行索引/赋值.例如:
>>> df = pd.DataFrame([[np.nan, 2, 5], [2, 5, np.nan], [2, 5, np.nan]])
>>> df # example frame
0 1 2
0 NaN 2 5
1 2 5 NaN
2 2 5 NaN
>>> df[df.notnull()] = 1
>>> df
0 1 2
0 NaN 1 1
1 1 1 NaN
2 1 1 NaN
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。