如何从Python列表中删除重复项并保持顺序?

Jos*_*ver 71 python sorting list unique

给定一个字符串列表,我想按字母顺序对其进行排序并删除重复项.我知道我可以这样做:

from sets import Set
[...]
myHash = Set(myList)
Run Code Online (Sandbox Code Playgroud)

但我不知道如何按字母顺序从散列中检索列表成员.

我没有和哈希结婚,所以任何方法都可以实现.此外,性能不是问题,因此我更倾向于使用代码清楚地表达一个快速但更不透明的解决方案.

Rod*_*ius 190

可以使用内置函数对列表进行排序和重复数据删除:

myList = sorted(set(myList))
Run Code Online (Sandbox Code Playgroud)
  • set 是Python> = 2.3的内置函数
  • sorted 是Python> = 2.4的内置函数

  • 如果myList具有不可用的对象,则此方法无效. (13认同)
  • 表现力和简洁的完美结合.谢谢,罗德! (7认同)
  • 否决是因为有序和排序之间存在区别。Ordered 表示保持原始顺序,例如 f([3,1,4,1,5,9,2,6,5,3,5]) = [3,1,4,5,9,2,6] (2认同)

syk*_*ora 11

如果您的输入已经排序,那么可能有一种更简单的方法:

from operator import itemgetter
from itertools import groupby
unique_list = list(map(itemgetter(0), groupby(yourList)))
Run Code Online (Sandbox Code Playgroud)

  • 这也可以表示为[e for e,_ in groupby(sortedList)] (4认同)

Paw*_*iak 5

如果要保持原始列表的顺序,只需使用OrderedDict与None作为值。

在Python2中:

    from collections import OrderedDict
    from itertools import izip, repeat

    unique_list = list(OrderedDict(izip(my_list, repeat(None))))
Run Code Online (Sandbox Code Playgroud)

在Python3中,它甚至更简单:

    from collections import OrderedDict
    from itertools import repeat

    unique_list = list(OrderedDict(zip(my_list, repeat(None))))
Run Code Online (Sandbox Code Playgroud)

如果您不喜欢迭代器(压缩和重复),则可以使用生成器(在2和3中均可使用):

    from collections import OrderedDict
    unique_list = list(OrderedDict((element, None) for element in my_list))
Run Code Online (Sandbox Code Playgroud)