Python关于删除list中的某个元素,一般有两种方法,pop()和remove()。
remove()
函数用于移除列表中某个值的第一个匹配项。
remove()
方法语法:
list.remove(obj)
pop()
函数用于移除列表中的一个元素(默认最后一个元素),并且返回该元素的值。
pop()
方法语法:
list.pop(obj=list[-1])
如果删除单个元素,使用基本没有什么问题,具体如下。
1.pop()方法,传递的是待删除元素的index:
1
2
3
4
5
6
7
|
x = [ 'a' , 'b' , 'c' , 'd' ] x.pop( 2 ) print x - - - - - - - - - - - - - - - - - - result: [ 'a' , 'b' , 'd' ] |
2. remove()传递待删除元素,如果多个元素一样,默认删除第一个:
1
2
3
4
5
6
7
|
x = [ 'a' , 'b' , 'a' , 'c' , 'd' ] x.remove( 'a' ) print x - - - - - - - - - - - - - - - - - result: [ 'b' , 'a' , 'c' , 'd' ] |
如果要循环删除符合某个条件的元素,慎用!!
1
2
3
4
5
6
7
8
9
10
|
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' ] |
1
2
3
4
5
6
7
8
9
10
11
|
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在内存中的位置并未改变。用下面方法可以避免。
1
2
3
4
5
6
7
8
9
10
11
12
|
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并没有受影响。
总结
以上就是本文关于深入了解Python中pop和remove的使用方法的全部内容,希望对大家有所帮助。如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
原文链接:https://www.cnblogs.com/sunxiaotao/p/4462347.html