Python list遍历remove()时的一个小BUG

系统 206 0

有这样一个列表:

            
              s=list('abcdefg')

            
          

 现在因为某种原因我们需要从s中踢出一些不需要的元素,方便起见这里直接以踢出所有元素的循环代替:

            
              for e in s:
    s.remove(e)

            
          

 结果却是:

            
              In [3]: s
Out[3]: ['b', 'd', 'f']

            
          
多次示例后发现,这种remove方式保持着隔1删1的规律。
那么改一下代码看看出了什么问题:
              In [14]: i=0
In [15]: for e in s: 
    ...:     print("第"+str(i)+"次循环删前:s=",s) 
    ...:     print(e) 
    ...:     s.remove(e) 
    ...:     print("第"+str(i)+"次循环删后:s=",s) 
    ...:     i=i+1 

            
Python list遍历remove()时的一个小BUG_第1张图片
可以看到第1次循环时e的赋值跳过‘b’直接变成了‘c’,鉴于不太清楚底层内存分配和计数的原理,只能做以下推测:
第0次循环后s的因为remove了‘a’导致长度减小了1,第1次循环时依然按s[1]给e赋值,可惜此时s=['b','c','d','e','f','g'],导致e=s[1]=‘c’,这样就跳过了‘b’。
在其他语言中可能也会有这样的陷阱,在Python中应避免在遍历序列时直接删除序列的元素,这里有一个替代的办法,我们可以遍历s的一个copy:
                
                  # s[0:]替换成s.copy()也可以
for e in s[0:]:
    s.remove(e)

                
              

更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请请扫描上面二维码支持博主1元、2元、5元等您想捐的金额吧,狠狠点击下面给点支持吧

发表我的评论
最新评论 总共0条评论