python tips: for循环的小问题
在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. 如果修改了,记得循环过程中索引依次递增,终止条件是索引超过新列表范围。