li = [11,22,33,44]
for i in li :
li.remove(i)
print (li)
#输出
[22, 44]
for的运行过程,会有⼀个指针来记录当前循环的元素是哪一个, ⼀开始这个指针指向第0个,然后获取到第0个元素,紧接着删除第0个;这个时候,原来是第一个的元素会⾃动的变成第0个,然后指针向后移动⼀次, 指向1元素;此时原来的1已经变成了0, 原来的2变成了1,出现跳着删除的现象。
对列表a看一下循环的索引的变化
a = [1, 2, 3, 4]
for index, x in enumerate(a):
print(“索引是{},去删除的值是{},列表的长度是{}”.format(index, x, len(a)))
a.remove(x)
print("=" * 20)
print(a)
结果如下:
索引是0,去删除的值是1,列表的长度是4
索引是1,去删除的值是3,列表的长度是3
[2, 4]
列表的长度在变化,索引值也在变化。这个是容易忽视的一个点,原因是for循环的对象是一个可迭代的对象。迭代的时候,索引会从零加到迭代对象长度,如果在迭代过程中删除了元素,导致长度变短迭代次数就会相应下降,容易出现问题。尽量不要再循环中直接去删除元素,可以把要删除的元素添加到另一个集合中然后再批量删除。