Python list列表中删除多个重复元素操作示例
本文实例讲述了Python list列表中删除多个重复元素操作。分享给大家供大家参考,具体如下:
我们以下面这个list为例,删除其中所有值为6的元素:
l=[9,6,5,6,6,7,8,9,6,0]
首先尝试remove方法:
l.remove(6)
print(l)
结果为:[9, 5, 6, 6, 7, 8, 9, 6, 0],只删除了第一个为6的元素。
如果采用for循环遍历各元素:
for x in l:
if x == 6:
l.remove(x)
结果为[9, 5, 7, 8, 9, 6, 0],后面的6没有删除。主要因为remove改变了list长度和每一个元素的位置。
采用del语句需要找到元素对应下标del l[1]。应用for循环改变下标比较混乱,所以使用while循环:
length=len(l)
x=0
while x < length:
if l[x] == 6:
# l.remove(l[x])
del l[x]
x -= 1
length -= 1
x += 1
结果为[9, 5, 7, 8, 9, 0],删除了列表中所有的6。另外将del l[x]改为l.remove(l[x])也可以。
补充:
最近发现了numpy的unique()函数可以去除列表中所有重复元素且将列表元素从小到大排序:
import numpy as np
l=[9,6,5,6,6,7,8,9,6,0]
a = np.unique(l)
print(a)
print(a)结果为[0 5 6 7 8 9]。l和a类型不同,前者是'list',后者是'numpy.ndarray'。
PS:本站还有两款比较简单实用的在线文本去重复工具,推荐给大家使用:
希望本文所述对大家Python程序设计有所帮助。
python list删除元素时要注意的坑点分享
我们直接先给出输出与预期不同的代码
In[28]: a = [1,2,3,4,5,6]
In[29]: for i in a:
...: a.remove(i)
...:
In[30]: a
Out[30]: [2, 4, 6]
在上述for循环中,假设我们删除了index=2的值,原本index=3及之后的值会向前补位,所以在循环中就跳过了原index=3的变量
同理,使用list.pop()函数删除指定元素的时候,也会出现上述情况,如:
In[33]: a = [1,2,3,4,5,6]
In[34]: for index, value in enumerate(a):
...: a.pop(index)
...:
In[35]: a
Out[35]: [2, 4, 6]
如果我们想循环删除列表中的元素,较简单的可用方法有:用一个临时列表保存待删除的元素,在for循环临时列表来删除老列表中的元素;或者直接用剩余元素列表覆盖原列表