在python中,用for对列表进行遍历的时候,迭代器中维护的是列表的索引而不是列表的元素。也就是说,for循环是对索引进行迭代,如果在for循环过程中修改了列表,迭代出来的值是新列表的索引位置,如果索引超过了新列表的范围,循环终止。
例子:
def for_test1():
x = list(range(10))
for index, value in enumerate(x):
print("delete:", x)
print("index:", index, "value:", value)
del x[index]
print("x:", x)
if __name__ == "__main__":
for_test1()
输出结果:
delete: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
index: 0 value: 0
delete: [1, 2, 3, 4, 5, 6, 7, 8, 9]
index: 1 value: 2
delete: [1, 3, 4, 5, 6, 7, 8, 9]
index: 2 value: 4
delete: [1, 3, 5, 6, 7, 8, 9]
index: 3 value: 6
delete: [1, 3, 5, 7, 8, 9]
index: 4 value: 8
x: [1, 3, 5, 7, 9]
上例中,在对x列表进行遍历的过程中删掉其中的元素,可以看到虽然列表被改变了,循环的索引仍然是依次递增的,说明for循环是对索引进行迭代,然后依据索引去列表中取值。当索引超出了新列表的范围,循环终止。
不会停止的for循环:
1 def for_test2():
2 x = list(range(10))
3 j = 10
4 for i in x:
5 print(i)
6 x.append(j)
7 j += 1
8
9 if __name__ == "__main__":
10 for_test2()
由于终止条件是索引超过列表范围,上述的for循环不会终止。
结论:
1. 尽量不要在对列表遍历的过程中,修改列表
2. 如果修改了,记得循环过程中索引依次递增,终止条件是索引超过新列表范围。