首页 >后端开发 >Python教程 >如何在保持顺序的同时有效地从 Python 列表中删除重复项?

如何在保持顺序的同时有效地从 Python 列表中删除重复项?

DDD
DDD原创
2024-12-20 12:42:19538浏览

How to Efficiently Remove Duplicates from a Python List While Maintaining Order?

删除列表中的重复项

在 Python 中,检查列表中的重复项并返回没有重复项的新列表是一项常见任务。有多种方法可以实现此目的。

使用集合

集合是不同对象的无序集合。它们提供了一种删除重复项的有效方法。要从列表创建集合,只需将其传递给 set() 函数即可。要将其转换回列表,请使用 list() 函数。但是,此方法不会保留元素的原始顺序。

t = [1, 2, 3, 1, 2, 3, 5, 6, 7, 8]
list(set(t))  # [1, 2, 3, 5, 6, 7, 8]

维护顺序

如果保留原始顺序至关重要,则 collections.OrderedDict可以使用模块。 OrderedDict 维护项目的插入顺序。将列表转换为 OrderedDict,然后返回列表以保留顺序。

from collections import OrderedDict
list(OrderedDict.fromkeys(t))  # [1, 2, 3, 5, 6, 7, 8]

在 Python 3.7 中使用字典

在 Python 3.7 及更高版本中,常规字典还保持插入顺序。因此,您可以使用以下方法:

list(dict.fromkeys(t))  # [1, 2, 3, 5, 6, 7, 8]

注意事项

请注意,所有这些方法都要求列表中的项目是可散列的(即不可变的) 。如果项目不可散列(例如列表),则需要采用涉及嵌套循环比较的较慢方法。

以上是如何在保持顺序的同时有效地从 Python 列表中删除重复项?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn