在我的Python 2.7.2 IDLE解释器中:
>>> mylist = [1, 2, 3, 4, 5]
>>> for item in mylist:
mylist.remove(item)
>>> mylist
[2, 4]
为什么?
解决方法:
这是因为当您遍历列表时是python keeps track of the index in the list.请考虑以下代码:
for i in range(len(mylist)):
if i >= len(mylist):
break
item = mylist[i]
mylist.remove(item)
如果我们跟踪它(这实际上是python在您的代码中所做的事情),那么我们会看到,当我们删除列表中的项目时,右边的数字向左移动一个位置,以填补我们删除列表中的空白项目.正确的项目现在位于索引i处,因此它实际上不会在迭代中被看到,因为发生的下一件事是我们为for循环的下一次迭代增加i.
现在换一些聪明的东西.相反,如果我们向后遍历该列表,则将清除该列表:
for item in reversed(mylist):
mylist.remove(item)
原因是在for循环的每次迭代中,我们都会从列表末尾删除一项.由于我们总是从头开始删除项目,因此无需进行任何更改(假设列表中的唯一性-如果列表不是唯一的,则结果是相同的,但参数会变得更加复杂).
当然,如果您要删除列表中的所有项目,则可以非常轻松地做到这一点:
del mylist[:]
甚至是切片分配:
mylist[:] = []
(我之所以提到后者,是因为用其他不需要相同长度的项替换列表的段会很有用).