如何减少'列表中的重复

时间:2014-08-26 18:13:41

标签: python loops repeat

我无法想出减少列表中重复次数的最有效方法。

a = ['x','x','x','y','y','y','z','z','z','x','x','x','z','z','z','z','z','z']

所需的输出(如果我减少3组)将是:

a_reduced = ['x','y','z','x','z','z']

我正在考虑循环遍历每个元素并执行' [i]和[i + 1]和[i + 2]条件'事情,但我相信有一个超级简单有效的方法来实现这一点,我只是遗漏了一些东西。请帮助,谢谢!

1 个答案:

答案 0 :(得分:5)

如果你的重复总是以3组为单位,你可以这样做:

a = ['x','x','x','y','y','y','z','z','z','x','x','x','z','z','z','z','z','z']
a_reduced = a[::3]
print a_reduced
>>>['x', 'y', 'z', 'x', 'z', 'z']

这将只从列表中获取每个第3个元素。同样,这假设您的列表总是以3组为单位。如果不是,则会出现偏差。否则,如果你只是想要压缩所有独特的重复,你可以使用itertools.groupby来做到这一点:

from itertools import groupby
a = ['x','x','x','y','y','y','z','z','z','x','x','x','z','z','z','z','z','z']
a_reduced = [item[0] for item in groupby(a)]
print a_reduced
>>>['x', 'y', 'z', 'x', 'z']