最近写的代码漏洞百出,困扰于:
ValueError: cannot convert float NaN to integer
虽然已经有很多大佬做了相应的解答,下面说说我遇到的问题及其解决办法吧!~
存在的问题
本来是要遍历一个数据列表的,源代码部分如下:
for sd in slice_dt: data_sum.append(int(sd)) # 将切片的数存入单一集合simple_sum中
是的,
你木有看错,就这!!!
然后就给我报错(由于项目保密固然打个马(•́へ•́╬))
就这!就这!!就这!!!
从字面意思上理解是,“不能将浮点NaN(空值)转换为整数”。
意思就是遇到有空值的情况了呗!
首先应该想到的是,替换。
一起来搞定它
思路我们有了,不就是替换嘛。
直接两条语句判断干起来!
for sd in slice_dt: if sd == sd: # 判断是否为空,若不为空,则运行下面语句 data_sum.append(int(sd)) # 将切片的数存入单一集合simple_sum中 else: data_sum.append(0) # 消除空值项,若为空值则填为0
然后就能完美输出啦~