for循环读取数组遇问题:dexError: invalid index to scalar variable.
发布日期:2021-05-06 16:32:47 浏览次数:7 分类:技术文章

本文共 975 字,大约阅读时间需要 3 分钟。

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

上一篇:python for循环计算速度很慢
下一篇:Word设置每页不同的页眉/修改或去掉页眉横线/页眉标题在横线上下方的设置

发表评论

最新留言

路过按个爪印,很不错,赞一个!
[***.219.124.196]2025年03月22日 07时57分14秒