TypeError: ‘numpy.float64’ object cannot be interpreted as an integer
出错代码:
for i in range(overlap_ranges.shape[1]):
for j in range(overlap_ranges.shape[2]):
min_overlaps[:, i, j] = np.linspace(*overlap_ranges[:, i, j])
输入:overlap_ranges为np.array([[[0.5], [0.5], [0.5]], [[0.95], [0.95], [0.95]], [[10], [10], [10]]])
出错原因:
- 本地numpy版本1.17.2,支持np.linspace(0.5,0.95,10.0)最后一位作为np.float64输入,正常运行。
- 服务器numpy版本1.19.1,不支持np.linspace浮点数作为最后一个参数。
解决方法:
降维打击,高版本numpy降维:
pip install -U numpy==1.17.2
本文解决了一个在使用np.linspace()函数时遇到的问题,当最后一个参数为浮点数时,在numpy版本1.19.1下会出现TypeError。通过对比不同版本的numpy表现,发现高版本的numpy对此不兼容。解决方法是将numpy版本降级到1.17.2。
2629

被折叠的 条评论
为什么被折叠?



