使用set去重会打乱顺序,list(set(lst))适用于无需保序场景;需保序时推荐dict.fromkeys(),可高效保留原始顺序。

在Python中,用集合(set)给列表去重是一个常见且高效的方法。因为集合中的元素是**唯一且无序**的,所以可以利用它自动去除重复项。
基本方法:使用 set() 转换
将列表传入 set() 构造函数,会自动生成一个不含重复元素的集合,然后再转回列表。
示例代码:
original_list = [1, 2, 2, 3, 4, 4, 5]
unique_list = list(set(original_list))
print(unique_list) # 输出可能是 [1, 2, 3, 4, 5](顺序不保证)
注意:由于集合是无序的,原列表的元素顺序可能被打乱。
保持顺序的去重方法
如果希望去重后保留原始顺序,不能直接用 list(set(…))。可以结合集合记录已出现的元素,遍历原列表实现。
立即学习“Python免费学习笔记(深入)”;
示例代码(保持顺序):
original_list = [1, 2, 2, 3, 4, 4, 5]
seen = set()
unique_list = []
for item in original_list:
if item not in seen:
seen.add(item)
unique_list.append(item)
print(unique_list) # 输出 [1, 2, 3, 4, 5]
这种方法通过 seen 集合快速判断是否已存在,时间复杂度接近 O(n),效率高且保持顺序。
使用 dict.fromkeys() 的简洁写法(推荐)
Python 3.7+ 中字典保持插入顺序,可以用 dict.fromkeys() 实现一行去重并保留顺序。
示例代码:
original_list = [1, 2, 2, 3, 4, 4, 5]
unique_list = list(dict.fromkeys(original_list))
print(unique_list) # 输出 [1, 2, 3, 4, 5]
这比手动循环更简洁,是目前最常用的保持顺序去重方式。
基本上就这些。如果不需要保持顺序,直接用 list(set(lst)) 最快;需要顺序时,推荐用 dict.fromkeys()。
以上就是python中如何用集合set给列表去重?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1382017.html
微信扫一扫
支付宝扫一扫