Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1896449
  • 博文数量: 2467
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 24799
  • 用 户 组: 普通用户
  • 注册时间: 2020-11-26 14:30
个人简介

更多python、Linux、网络安全学习内容,可移步:www.oldboyedu.com或关注\"老男孩Linux\"公众号

文章分类

全部博文(2467)

文章存档

2024年(317)

2023年(643)

2022年(693)

2021年(734)

2020年(80)

我的朋友

分类: Python/Ruby

2023-06-13 17:23:24

  在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)

阅读(198) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~