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循环是对索引进行迭代,然后依据索引去列表中取值。当索引超出了新列表的范围,循环终止。

结论:

1. 尽量不要在对列表遍历的过程中,修改列表

2. 如果修改了,记得循环过程中索引依次递增,终止条件是索引超过新列表范围。

猜你喜欢

转载自www.cnblogs.com/luoheng23/p/10988025.html