在Python中,当列表出现重复元素时,可以通过以下这几种方式进行删除,觉得有用的小伙伴赶紧学起来吧,看完记得收藏哦! 1、直接遍历列表删除 l1 = [1,1,2,2,3,3,3,6,6,5,5,2,2] for el in l1: if l1.count(el) > 1: l1.remove(el) print(l1) #会漏删,因为删除一个元素后,后面的元素向前补位,导致紧跟的一个元素被跳过。 2、通过遍历索引删除 l1 = [1,1,2,2,3,3,3,3,6,6,5,5,2,2] for el in rnage(len(l1)): #此时len(l1)已经确定,不会随着l1后面的变化而变化 if l1.count(l1[el]) > 1: l1.remove(l1[el]) print(l1) #会报错,因为删除元素后导致l1的长度变短了,但是for遍历的还是之前的索引长度,会导致索引超过范围而报错 3、通过遍历创建的切片来删除原列表 l1 = [1,1,2,2,3,3,3,3,6,6,5,5,2,2] for el in l1[:]: if l1.count(el) > 1: l1.remove(el) #没有问题,可以去重,但是无法保留原有的顺序 print(l1) 4、用新列表记录需要保留的元素 l1 = [1,1,2,2,3,3,3,3,6,6,5,5,2,2] lst = [] for el in l1: if lst.count(el) < 1: lst.append(el) print(lst) #没有问题,也能保留原有顺序,但是创建了新列表 5、通过索引倒着删除 l1 = [1,1,2,2,3,3,3,3,6,6,5,5,2,2] for el in range(len(l1)-1,-1,-1): if l1.count(l1[el]) > 1: l1.pop(el) #没有问题,且保留原顺序 # l1.remove(l1[el]) #没有问题,但是不能保留原有顺序 # del l1[el] #这样则会保留原有顺序 print(l1) |
|
来自: 老男孩IT教育 > 《Python培训》