0

如何编写一个计算列表中字母数量的函数?例如:

    letter_list=['a','b','a','c','b','a']


    letter_index={'a':0,'b':1,'c':2}

我想得到以下结果:

    ([3,2,1])
4

3 回答 3

1

要获取列表中最常见的项目,或者只计算出现次数,请使用Counter类。

from collections import Counter
letter_list=('a','b','a','c','b','a')
counter = Counter(letter_list)
print counter.most_common(1)
# Prints 'a' because it's the most common element

从中您还可以获得每个元素的出现次数:

print counter['a'] # Prints 3

print counter.most_common() # Prints [('a', 5), ('r', 2), ('b', 2)]
于 2012-11-22T02:10:19.270 回答
0

只有一个小选择:

letter_list=('a','b','a','c','b','a')
def __get_res(lVals):
    unique = set(lVals)
    res = map(lVals.count, unique)
    return (max(unique, key=lVals.count), map(lVals.count, unique))

print __get_res(letter_list)
于 2012-11-22T02:20:48.373 回答
0

尝试使用 dict 理解。此外,letter_list在您的示例中是 a tuple,而不是 a list

>>> letter_list = ['a','b','a','c','b','a']    
>>> {x:letter_list.count(x) for x in letter_list}
{'a': 3, 'c': 1, 'b': 2}

要获得列表中出现次数最多的项目,您可以使用@BoppreHCounter详述的模块,或者您可以执行类似的操作。

>>> max(set(letter_list), key=letter_list.count)
'b'
于 2012-11-22T02:09:23.840 回答