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

如何在 Python 中删除列表中的重复项,同时保持原始顺序?

Barbara Streisand
Barbara Streisand原创
2024-12-23 07:01:07851浏览

How Can I Remove Duplicates from a List While Maintaining Original Order in Python?

在保留列表顺序的同时处理重复项

处理包含重复元素的列表时,通常需要在保持原始顺序的同时删除它们。使用集合来实现这一点,因为它忽略了原始序列。然而,Python 提供了几种在删除重复项的同时保留顺序的替代方法。

内置函数和 Python 习语

  • Peter Be 的基准: https://www.peterbe.com/plog/uniqifiers-benchmark
  • 最快的解决方案:
def f7(seq):
    seen = set()
    seen_add = seen.add
    return [x for x in seq if not (x in seen or seen_add(x))]

此解决方案将 saw.add 分配给 saw_add为了提高效率,由于 Python 的动态语言,在循环迭代期间重复调用 saw.add 可能会带来性能开销大自然。

  • 订购套餐(食谱): https://code.activestate.com/recipes/528878-ordered-set/
  • 订购套装属性:

    • O(1) 插入、删除和成员检查操作
  • 注意: 使用 "或”在上面的代码中的 saw.add 之后只是一种尝试集合更新的机制,而不是逻辑的重要部分

通过利用这些方法,开发者可以在不牺牲原始顺序的情况下从列表中删除重复元素,满足特定的数据操作场景。

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

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