pandas报错ValueError: Cannot convert non-finite values (NA or inf) to integer

  统计/机器学习 Python    浏览次数:3942        分享
0

我用df['col'].astype(int)转换成int类型时候,出现了以下错误

ValueError: Cannot convert non-finite values (NA or inf) to integer

应该是原数据中含有nan或者inf导致的,我想要得到整数型有什么解决办法呢?

 

vivian_o   2018-11-24 13:39



   1个回答 
4

np.nan或者np.inf都是float的类型,而且无法转成int,所以就报错了

建议把nan或者inf替换成0之类的

df.replace(np.nan, 0, inplace=True)
df.replace(np.inf, 0, inplace=True)


SofaSofa数据科学社区DS面试题库 DS面经

zl_pku   2018-11-25 22:18



  相关主题

pandas里index的问题   1回答

找到pd.DataFrame中某个列名对应的下标?   1回答

pd.cut怎么用?   2回答

将pandas.DataFrame中的-1全部换成0   1回答

怎么把一个pandas数据框用append的方式添加到现有的csv文件?   2回答

怎么添加pandas的dataframe到已有的csv文件,并且不覆盖原内容   1回答

怎么改变pandas dataframe里column的顺序?   1回答

pandas DataFrame中经常出现SettingWithCopyWarning   2回答

怎么利用pandas获得一个列联表(contingency table)?   1回答

pandas dataframe insert报错ValueError: unbounded slice   1回答

pandas.DataFrame的index重新排列(从0开始)   2回答

python或者pandas读取excel xlsx文件中指定的一个sheet   1回答



回答问题时需要注意什么?

我们谢绝在回答前讲“生动”的故事。

我们谢绝“这么简单,你自己想”、“书上有的,你认真看”这类的回答;如果你认为对方的提问方式或者内容不妥,你可以直接忽略该问题,不用进行任何作答,甚至可以对该问题投反对票。

我们谢绝答非所问。

我们谢绝自己不会、硬要回答。

我们感激每一个用户在编写答案时的努力与付出!