我是靠谱客的博主 失眠冰棍,最近开发中收集的这篇文章主要介绍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').所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(44)

评论列表共有 0 条评论

立即
投稿
返回
顶部