为什么会出现此类错误?
通常情况下,我现在只使用enumerate()
,但我特别想在这个给定的范围内进行迭代:
r1 = (0,0,100,100)
r2 = (20,20,40,40)
r3 = (40,40,80,80)
these_objects = []
objects.append(r1)
objects.append(r2)
objects.append(r3)
objects_clone = copy.copy(these_objects)
iterations = int(len(objects_clone))-1
print(iterations)
for this_index, this_object in range(0, iterations):
# ...
例外:
2
Traceback (most recent call last):
File "test/test.py", line 50, in <module>
for this_index, this_object in range(0, iterations):
TypeError: 'int' object is not iterable
答案 0 :(得分:1)
range(0, iterations)
对象产生整数,而不是元组。您要求for
循环将每个整数解包为两个变量:
for this_index, this_object in range(0, iterations):
解包整数失败:
>>> this_index, this_object = 0
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: 'int' object is not iterable
您可以迭代索引并在一秒钟内提取对象:
for this_index in range(iterations):
this_object = objects_clone[this_index]
# ...
如果你想枚举除了最后一个对象之外的所有对象,也许你想 slice 忽略最后一个元素:
for this_index, this_object in enumerate(objects_clone[:-1]):
# ...
答案 1 :(得分:0)
如果你想将索引和元素放在一起,你应该确实使用enumerate()
。这就是它的用途。另一方面,range()
一次给你一个对象:一个整数。并且,由于每个整数只有一个对象,因此您无法将每个整数解包为两个对象。这就是为什么for i in range(num):
是一个常见的结构,而for i,j in range(num):
不是。