为什么list.remove只删除第二个项目?

在我的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[:] = []

(我之所以提到后者,是因为用其他不需要相同长度的项替换列表的段会很有用).

上一篇:javascript-for-in循环VS in-operator


下一篇:javascript – 从“命名空间”字符串构建对象层次结构