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

时间:2012-11-22 02:04:32

标签: python

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

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


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

我想得到一个结果:

    ([3,2,1])

3 个答案:

答案 0 :(得分: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)]

答案 1 :(得分:0)

尝试使用dict理解。此外,您示例中的letter_listtuple,而不是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}

要获取列表中发生率最高的项目,您可以使用 @BoppreH 详细说明的Counter模块,或者您可以执行此类操作。

>>> max(set(letter_list), key=letter_list.count)
'b'

答案 2 :(得分: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)