用for循环从文档中读取数组时,遇到一个bug,只能循环完成第一个循环,第二个循环就报错:dexError: invalid index to scalar variable.
其实是变量设置的问题,代码如下:
...
with open(save_path, 'rb') as fi1:
result = pickle.load(fi1, encoding='iso-8859-1')
name, fx = zip(*result)
for i in range(0, 10):
fx = np.array(fx)[i]
f_top_id = fx.argsort()[::-1][0:10] # 排序,得到由高到低的序号
print('i & fx:',i, fx[f_top_id[i]])
...
上面这段代码就是想从文档中的矩阵中一行接一行的提取数组,在for循环中读取第一行没问题,读出第二行就报错,其实原因很简单,低级错误,弄了几个小时debug,太不注意了,之前也遇到过。
问题出在fx
这里,从name, fx = zip(*result)
得到后,放入循环中又继续用这个变量名fx = np.array(fx)[i]
,这就炸锅了,第二次循环就肯定报错,因为fx
在第一个循环的参数又直接导入到第二个循环中的fx
,这就是问题所在,实际上需要fx
的数据保持不变。
解决方法:在for循环中的fx
改成其他变量名就解决了,如f_x
就可以了,改完如下:
...
with open(save_path, 'rb') as fi1:
result = pickle.load(fi1, encoding='iso-8859-1')
name, fx = zip(*result)
for i in range(0, 10):
f_x = np.array(fx)[i]
f_top_id = f_x.argsort()[::-1][0:10] # 排序,得到由高到低的序号
print('i & fx:',i, f_x[f_top_id[i]])
...
记录debug的问题,加深记忆,也希望能给其他遇到同样报错的人一些启发,也感谢其他人的分享。