我正在运行一个代码,其中包含一系列列表。我使用以下方法访问随机索引(假设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]并且它有效。我不知道为什么会发生这种情况,也不知道如何解决这个问题。任何帮助,将不胜感激。
答案 0 :(得分:2)
您的y
是使用len
list2
(无论是什么)设置的,并且设置在1的下限。因此,如果list2
比列表中的list1[x]
更长list1[x]
或IndexError
为空,您将收到此错误。
修改强>: 我刚刚注意到你问题的一部分,你在try / except中提到了这个问题。是的,{{1}}是可以捕获的,但在实现这样的事情之前,你应该尝试调试你的实际问题。如果您不知道为什么正在发生,那么抛出try / except块可能会产生巨大的性能瓶颈(取决于异常的可能性),甚至会导致无限循环(如果是一定)。