我是靠谱客的博主 失眠冰棍,最近开发中收集的这篇文章主要介绍ValueError: Input contains NaN, infinity or a value too large for dtype('float64').,觉得挺不错的,现在分享给大家,希望可以做个参考。
概述
问题:
在训练模型 fit(x_train,y_train) 时遇到报错
ValueError: Input contains NaN, infinity or a value too large for dtype('float64')
解决方法:
1、检查数据中是否有缺失值,并做缺失值处理
# 读取数据
train = pd.read_csv('./data/train.csv')
# 检查数据中是否有缺失值,以下两种方式均可
#Flase:对应特征的特征值中无缺失值
#True:有缺失值
print(train.isnull().any())
print(np.isnan(train).any())
#查看缺失值记录
train_null = pd.isnull(train)
train_null = train[train_null == True]
print(train_null)
#缺失值处理,以下两种方式均可
#删除包含缺失值的行
train.dropna(inplace=True)
#缺失值填充
train.fillna('100')
2、检查数据中是否有无穷数据,并做数据处理
#检查是否包含无穷数据
#False:包含
#True:不包含
print(np.isfinite(train).all())
#False:不包含
#True:包含
print(np.isinf(train).all())
#数据处理
train_inf = np.isinf(train)
train[train_inf] = 0
最后
以上就是失眠冰棍为你收集整理的ValueError: Input contains NaN, infinity or a value too large for dtype('float64').的全部内容,希望文章能够帮你解决ValueError: Input contains NaN, infinity or a value too large for dtype('float64').所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复