![[报错]TypeError: ‘numpy.float64‘ object cannot be interpreted as an integer,第1张 [报错]TypeError: ‘numpy.float64‘ object cannot be interpreted as an integer,第1张](/aiimages/%5B%E6%8A%A5%E9%94%99%5DTypeError%3A+%E2%80%98numpy.float64%E2%80%98+object+cannot+be+interpreted+as+an+integer.png)
看错误提示的类型:TypeError
也就是说明由于数据类型的原因导致运算出错。
现记录下出错的情况种类。
一、list列表的运算
list和np.ndarray在形式上类似,导致好多人认为np的运算可以适用于list.但显然不是的。
list数据类型不能像numpy.array或者matrix一样进行elementwise *** 作. r_env += (0.9 ** i) * r_env1
TypeError: can’t multiply sequence by non-int of type ‘float’。
无法将序列与“float”类型的非int相乘。
要的是逐元素乘法,将r_env1改为np.array
二、
int(np.min(np.mean(D),np.median(D)))/5
## D是一个二维的numpy矩阵
报错:TypeError: ‘numpy.float64’ object cannot be interpreted as an integer.
查错步骤:
查看 np.mean(D),np.median(D)的类型均为 np.float64
查看 np.min()后的结果类型
type(np.min(np.mean(D), np.median(D)) ),报错为上。
原因:
np.min()的对象必须是np.array,而我的是两个数值比较大小。
只要修改为
min()函数即可。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)