zoukankan      html  css  js  c++  java
  • 慎用python的pop和remove方法

    申明:转载请注明出处!!!

    Python关于删除list中的某个元素,一般有两种方法,pop()和remove()。

    如果删除单个元素,使用基本没有什么问题,具体如下。

    1.pop()方法,传递的是待删除元素的index:

    x = ['a', 'b', 'c', 'd']
    x.pop(2)
    print x
    
    ------------------
    result:
    ['a', 'b', 'd']
    

      

    2. remove()传递待删除元素,如果多个元素一样,默认删除第一个:

    x = ['a', 'b', 'a', 'c', 'd']
    x.remove('a')
    print x
    
    -----------------
    result:
    ['b', 'a', 'c', 'd']
    

      

    如果要循环删除符合某个条件的元素,慎用!!

    x = ['a', 'b', 'c', 'd']
    y = ['b', 'c']
    for i in x:
    	if i in y:
    		x.remove(i)
    print x
    
    -----------------------
    result:
    ['a', 'c', 'd']
    

      

    x = ['a', 'b', 'c', 'd']
    y = ['b', 'c']
    for i in x:
    	if i in y:
    		idx = x.index(i)
    		x.pop(idx)
    print x
    
    --------------
    result:
    ['a', 'c', 'd']
    

      我认为出现这种情况的主要原因是,pop和remove方法属于‘破坏性操作‘(ps:原谅我自创的定义),x.remove()后,内存中原来存放x的位置已经释放,又重新申请了内存存放新的x。可以理解为x已经不是原来的x了,而for循环中传递的x还是原来x在内存中的位置,所以在x.remove(i)后,for循环找不到x了,后面的删除即无法完成。为了完成循环删除list元素的问题,我推荐用下面的方法。

      感谢也许小念旧 的提醒,原先的解释是错误的,造成上述现象的原因是因为,Python中for i in list是用迭代器实现,内部隐藏了记录当前迭代器的状态,而remove方法删除了当前元素后,迭代器自动指到下一个元素,原先的list在内存中的位置并未改变。用下面方法可以避免。

    x = ['a', 'b', 'c', 'd']
    y = ['b', 'c']
    x_new = []
    for i in x:
    	if i not in y:
    		x_new.append(i)
    x = x_new
    print x
    
    ----------------------
    result:
    ['a', 'd']
    

      

      同时, 可可可心一家 提出把for i in x:改成for i in x[:]:也可以实现,这是因为x[:]与x不是同一个list,相当与把x的内存拷贝到一块新的内存,当对x做remove操作的时候,新的内存list并没有受影响。

  • 相关阅读:
    我的开源2009
    Kooboo CMS
    Visual Studio 2008丢失XML高亮和提示
    Kooboo完全介绍二:创建第一个Kooboo站点
    Telnet发送邮件和.NET邮件匿名发送组件
    C#中循环结构的效率问题 Virus
    从Android中Activity之间的通信说开来 Virus
    新浪微博开放平台开发android客户端(2) Virus
    MongoDB在Windows2003上得安装配置及使用 Virus
    消息提示的架构演进理论篇 Virus
  • 原文地址:https://www.cnblogs.com/sunxiaotao/p/4462347.html
Copyright © 2011-2022 走看看