登录
首页 >  文章 >  python教程

Python列表去重技巧全解析

时间:2025-12-01 10:48:30 242浏览 收藏

对于一个文章开发者来说,牢固扎实的基础是十分重要的,golang学习网就来带大家一点点的掌握基础知识点。今天本篇文章带大家了解《Python列表去重方法大全》,主要介绍了,希望对大家的知识积累有所帮助,快点收藏起来吧,否则需要时就找不到了!

Python列表去重推荐使用list(dict.fromkeys(lst))保留顺序,1.用set()去重但不保序;2.dict.fromkeys()保序且高效;3.列表推导式+集合适用于复杂逻辑;4.不可哈希元素可转元组处理。

python对列表中的元素进行去重操作

Python中对列表元素去重有多种方法,根据是否需要保持原有顺序以及数据类型的不同,可以选择合适的方式。

1. 使用set()(不保留顺序)

最简单的方法是将列表转换为集合,再转回列表。但注意:这会丢失原始顺序。

lst = [1, 3, 2, 2, 4, 3, 5]
unique_lst = list(set(lst))
print(unique_lst)  # 输出顺序可能不同,如 [1, 2, 3, 4, 5]

适用场景:只关心唯一值,不关心顺序时使用。

2. 使用dict.fromkeys()(保留顺序)

从Python 3.7起,字典保持插入顺序,因此可用此方法高效去重并保留顺序。

lst = [1, 3, 2, 2, 4, 3, 5]
unique_lst = list(dict.fromkeys(lst))
print(unique_lst)  # 输出: [1, 3, 2, 4, 5]

推荐方式:这是目前最简洁且高效保留顺序的去重方法。

3. 使用列表推导式 + 辅助集合(保留顺序,灵活控制)

如果需要更复杂的判断逻辑,可以用遍历方式手动维护已见元素。

lst = [1, 3, 2, 2, 4, 3, 5]
seen = set()
unique_lst = [x for x in lst if not (x in seen or seen.add(x))]
print(unique_lst)  # 输出: [1, 3, 2, 4, 5]

利用 seen.add(x) 返回None的特性,实现一行判断与记录。

4. 对不可哈希元素去重(如嵌套列表)

若列表中包含列表等不可哈希类型,不能用set或dict方法。可转换为元组后处理。

lst = [[1, 2], [2, 3], [1, 2], [3, 4]]
seen = set()
unique_lst = []
for item in lst:
    tup = tuple(item)
    if tup not in seen:
        seen.add(tup)
        unique_lst.append(item)
print(unique_lst)  # 输出: [[1, 2], [2, 3], [3, 4]]

注意:仅适用于子元素都可转为元组的情况。

基本上就这些常用方法。多数情况下推荐 list(dict.fromkeys(lst)),简洁又高效。

今天关于《Python列表去重技巧全解析》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

前往漫画官网入口并下载 ➜
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>