修正"指数超出范围"代码中的错误

时间:2014-03-12 20:53:23

标签: python list numpy

我正在运行一个代码,其中包含一系列列表。我使用以下方法访问随机索引(假设list1是包含列表的列表.list1中的每个列表具有相同的长度,所以我只将list2等同于其中一个列表):

import numpy as np

x=np.random.randint(0, len(list1))
y=np.random.randint(1, len(list2))

print list1[x][y]

这显然只是我实际写的一个粗略的近似,但它遵循相同的路线。出于某种原因,有时我会得到超出范围的"索引"错误,我不明白为什么,因为numpy randint模块高端独占。为什么会这样?

此外,有没有办法编写一个代码块来尝试x和y索引并查看它是否有效以及是否涉及错误,只需选择两个新的随机索引? try-except块可以用于此吗?

修改

以下是我正在使用的代码:

 ridx=np.random.randint(0,len(l_bg_2))
 ridy=np.random.randint(1,len(l_bg))
 print (ridx,ridy)
 while ((bg_dict.has_key((ridx, ridy))) or (ridy==0)):
     if bg_dict.has_key((ridx, ridy)):
         ridx=np.random.randint(0,len(l_bg_2))
         ridy=np.random.randint(1,len(l_bg))
         print (ridx, ridy)
     if ridy==0:
         ridy=np.random.randint(1,len(l_bg))
         print (ridx, ridy)
 bg_dict[(ridx, ridy)]=1
 p['bg'] = (l_bg_2[ridx])[ridy]

我在print语句中添加了以捕获哪些索引给出了索引错误。我最后一次运行代码时,在ridx = 41,ridy = 451时,l_bg_2 [ridx] [ridy]得到索引错误。然后我运行了一个print语句来获得l_bg_2 [41] [451]并且它有效。我不知道为什么会发生这种情况,也不知道如何解决这个问题。任何帮助,将不胜感激。

1 个答案:

答案 0 :(得分:2)

您的y是使用len list2(无论是什么)设置的,并且设置在1的下限。因此,如果list2比列表中的list1[x]更长list1[x]IndexError为空,您将收到此错误。

修改: 我刚刚注意到你问题的一部分,你在try / except中提到了这个问题。是的,{{1}}是可以捕获的,但在实现这样的事情之前,你应该尝试调试你的实际问题。如果您不知道为什么正在发生,那么抛出try / except块可能会产生巨大的性能瓶颈(取决于异常的可能性),甚至会导致无限循环(如果是一定)。