for循环读取数组遇问题:dexError: invalid index to scalar variable.

用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的问题,加深记忆,也希望能给其他遇到同样报错的人一些启发,也感谢其他人的分享。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章