如何编写一个计算列表中字母数量的函数?例如:
letter_list=['a','b','a','c','b','a']
letter_index={'a':0,'b':1,'c':2}
我想得到以下结果:
([3,2,1])
如何编写一个计算列表中字母数量的函数?例如:
letter_list=['a','b','a','c','b','a']
letter_index={'a':0,'b':1,'c':2}
我想得到以下结果:
([3,2,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)]
只有一个小选择:
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)
尝试使用 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'