Python删除列表元素不全

给出一个列表x,一个一个地删除列表中的元素,代码很容易写成这样:

x=[1,2,3,4,5,6]
for i in x:
    del x[0]

这样写结果x=[]吗?NO!!!(本来我以为是的)结果是[4,5,6]
原因:
Python会自动对列表内存进行收缩并移动列表元素以保证所有元素之间没有空隙,增加列表元素也会自动扩展内存并对元素进行移动,每当插入或删除一个元素,该元素位置后面的元素的索引就都改变了。
list删除
所以看这个例子:
删除列表中值为1的元素,这样写也是不对的:

x=[1,2,1,2,1,2,1,2]
for i in x:
    if i==1:
        x.remove(i)

但是结果x是[2,2,2,2],结果又是对的,如果列表开始有连续的‘1’,就无法删除了。

x=[1,2,1,2,1,1,1]
for i in x:
    if i==1:
        x.remove(i)

这个x最后是[2,2,1],为什么这样和上面的原因是一样的!

猜你喜欢

转载自blog.csdn.net/xlm11/article/details/52430679