-11

我有一个清单:

 X = ['raz', 'dwa', 'raz', 'trzy', 'dwa', 'raz', 'trzy', 'cztery']

并想要输出:

{'cztery': 1, 'dwa': 2, 'raz': 3, 'trzy': 2}
4

3 回答 3

4

您可以使用字典理解

>>> lst = ['raz', 'dwa', 'raz', 'trzy', 'dwa', 'raz', 'trzy', 'cztery']
>>> {x:lst.count(x) for x in set(lst)}
{'raz': 3, 'cztery': 1, 'dwa': 2, 'trzy': 2}
>>>

或者,您可以使用collections.Counter

>>> from collections import Counter
>>> Counter(lst)
Counter({'raz': 3, 'dwa': 2, 'trzy': 2, 'cztery': 1})
>>>

第二种解决方案可能是您想要的,因为它与理解执行相同的操作,更高效,并且还使用Counter类,它带有许多很棒的工具(例如most_commonsubtract)。

于 2013-10-10T18:41:20.233 回答
1

使用 stdlib 的另一种方法:

In [6]: from collections import Counter
In [7]: l = ['raz', 'dwa', 'raz', 'trzy', 'dwa', 'raz', 'trzy', 'cztery']
In [8]: dict(Counter(l).items())
Out[8]: {'cztery': 1, 'dwa': 2, 'raz': 3, 'trzy': 2}
于 2013-10-10T18:45:40.713 回答
0

只是用groupby布赖恩建议的方式演示版本。

import itertools
data = ['raz', 'dwa', 'raz', 'trzy', 'dwa', 'raz', 'trzy', 'cztery']
print({k:len(list(v)) for k, v in itertools.groupby(sorted(data))})
于 2013-10-10T18:50:29.807 回答