删除列表中的重复项
在 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中文网其他相关文章!