Python删除列表中重复元素的方法有哪些

直接遍历列表删除

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)# 会漏删,因为删除一个元素后,后面的元素向前补位,导致紧跟的一个元素被跳过.

登录后复制

通过遍历索引删除

l1 = [1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]for el in range(len(l1)):  # 此时len(l1)已经确定,不会随着l1后面的变化而变化    if l1.count(l1[el]) > 1:        l1.remove(l1[el])print(l1)  # 会报错,因为删除元素后导致l1的长度变短了,但是for遍历的还是之前的索引长度,会导致索引超过范围而报错

登录后复制

通过遍历创建的切片来删除原列表

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)

登录后复制

用新列表记录需要保留的元素

l1 = [1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]lst = []for el in l1:    if lst.count(el) 

通过索引倒着删除

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)

登录后复制

通过递归函数删除

l1 = [1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]def set_lst(lst):    for el in lst:        if lst.count(el) > 1:            lst.remove(el)            set_lst(lst)    # 每次开辟一个新函数,判断上次被删除了一个元素后的列表    else:  # 直到最后,列表里的元素都是一个,运行了else        return lstprint(set_lst(l1))  # 因为是从前面开始删除的,所以不保留原有顺序'''[1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2][1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2][1, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2][1, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2][1, 3, 3, 3, 6, 6, 5, 5, 2, 2][1, 3, 3, 6, 6, 5, 5, 2, 2][1, 3, 6, 6, 5, 5, 2, 2][1, 3, 6, 5, 5, 2, 2][1, 3, 6, 5, 2, 2][1, 3, 6, 5, 2]   return lst = [1, 3, 6, 5, 2]'''

登录后复制

毫无疑问set()是最方便的

l1 = [1, 1, 2, 2, 3, 3, 3, 3, 6, 6, 5, 5, 2, 2]lst = list(set(l1))print(lst)

登录后复制

以上就是Python删除列表中重复元素的方法有哪些的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2238989.html

(0)
上一篇 2025年2月26日 19:38:06
下一篇 2025年2月18日 06:40:42

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论