天天看点

python统计字典中元素个数_python 利用字典对列表中元素个数计数

方法一:利用字典的get函数,get表示根据字典的key取它的value值,如果该key不存在,则value值会默认为get的第二个参数。

values=[1,2,3,2,3,1,4]

values_cnt={}

for value in values:

value_cnt[value]=values_cnt.get(value,0)+1

方法三:定义一个新的计数字典,用来放元素及其个数。为了防止产生异常,应该判断计数字典中是否有该元素,这样才能作为可key来进行访问。

list1=[1,3,2,4,2,3]

dict_cnt={} #dict_cnt=dict()

for item in list1:

if item in dict_cnt: #直接判断key在不在字典中

dict_cnt[item]+=1

else:

dict_cnt[item]=1

方法二:利用collections中的defaultdict()

defaultdict()可以接受一个参数,如str,int,float等。但这个参数并不是来约束字典的key的值的类型,也不是用来约束value的值的类型。而是当字典的key不存在时,将value初始化为某个值。str初始化为“”,int初始化为0,float初始化为0.0。

from collections import defaultdict

list1=[1,2,3,4,3,2]

count_dict=defaultdict(int)

for item in lists:

count_dict[item]+=1

方法四:利用collections中的Counter函数

from collections import Counter

list1=[1,2,3,4,3,2,1]

a=Counter(list1)

print(a) # Counter({1:2,2:2,3:2,4:1})

a.elements() #获取a中的所有的键,返回的是一个对象,可以通过list来转化它

a.most_common(2) #返回前两个出现频率最高的以及他们的键,列表里面嵌套元祖的方式

a['zz'] #访问不存在的时候,自动返回为0

a.update("aa5bzz") #更新被统计的对象,即原有的计数值与新增的相加,而不是替换

a.subtrct("aaa5z") #实现与原来的计数值相减,结果运行为0和负值