如何编写一个计算列表中字母数的函数? 例如:
letter_list=['a','b','a','c','b','a']
letter_index={'a':0,'b':1,'c':2}
我想得到一个结果:
([3,2,1])
答案 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_list
为tuple
,而不是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)