时间:2021-05-22
这个问题源于在训练机器学习的一个模型时,使用训练数据时提示prepare的数据中存在np.nan
报错信息如下:
ValueError: np.nan is an invalid document, expected byte or unicode string.刚开始不知道为什么会有这个,后来发现是list中存在nan值
下面是找到nan值的方法:
简单找到:
import numpy as npx = np.array([2,3,np.nan,5, np.nan,5,2,3])for item in x: if np.isnan(item): print('yes')
拿到index数组:
然而实际上,有些时候,如果是用pandas读出的数据,在list中print时提示为nan,但用isnan方法却并不能正确判断,会提示TypeError,此时需要用pandas.isnull()判断该值是否为空
下面是numpy.isnan()的文档
以上这篇Python Numpy:找到list中的np.nan值方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
实例如下所示:>>>importpandasaspd>>>importnumpyasnp>>>ts1=[0,1,np.nan,np.nan,np.nan,np.
处理方式:存在缺失值nan,并且是np.nan:删除存在缺失值的:dropna(axis='rows')替换缺失值:fillna(df[].mean(),inp
如下所示:importnumpyasnpnp.set_printoptions(threshold=np.nan)print(ndarray)当ndarray里
nan:notanumberinf:infinity;正无穷numpy中的nan和inf都是float类型t!=t返回bool类型的数组(矩阵)np.count
Python中numpy数组的合并有很多方法,如-np.append()-np.concatenate()-np.stack()-np.hstack()-np.