Counter作为字典dicit()的一个子类用来进行hashtable计数,将元素进行数量统计,计数后返回一个字典,键值为元素,值为元素个数
切记Counter第一个字母是大写C
Counter创建:
有多种方式可以创建如下
from collections import Counter
lists=[2,3,2,2,3,4]
dicts={'a':2,"b":3,"c":2}
a=Counter(lists)
b=Counter(dicts)
c=Counter(a=2,b=3,c=2)
print(a)
print(b)
print(c)
输出:
Counter({2: 3, 3: 2, 4: 1})
Counter({'b': 3, 'a': 2, 'c': 2})
Counter({'b': 3, 'a': 2, 'c': 2})
update():
将值累加到Counter里,和set集合的update一样,对集合进行并集更新
from collections import Counter
c=Counter()
c.update("sdasda")#等于将数据累加进c中
print(c)
输出:
Counter({'s': 2, 'd': 2, 'a': 2})
elements():
返回经过计算器Counter后的元素,返回的是一个迭代器
from collections import Counter
c=Counter("asdasdasd")
k=list(c.elements())
print(k)
输出:
['a', 'a', 'a', 's', 's', 's', 'd', 'd', 'd']
most_common(num):
按照元素出现的次数进行从高到低的排序,返回前num个元素的字典
from collections import Counter
c=Counter("asdasdaassa")
for i , k in c.most_common(2):
print("%s:%d"%(i,k))
print(c.most_common(2))
输出:
a:5
s:4
[('a', 5), ('s', 4)]
+ - & |
Counter间支持操作符运算
from collections import Counter
a=Counter(a=2,b=3,c=1)
b=Counter('abcksdkb')
print()
print("now")
print(a)
print(b)
print()
print("+于update一样")
print(a+b)
print()
print("-减去含有的数量")
print(a-b)
print()
print("&共同拥有的")
print(a&b)
print()
print("|两个数据共同且取最多")
print(a|b)
输出:
now
Counter({'b': 3, 'a': 2, 'c': 1})
Counter({'b': 2, 'k': 2, 'a': 1, 'c': 1, 's': 1, 'd': 1})+
Counter({'b': 5, 'a': 3, 'c': 2, 'k': 2, 's': 1, 'd': 1})-
Counter({'a': 1, 'b': 1})&
Counter({'b': 2, 'a': 1, 'c': 1})|
Counter({'b': 3, 'a': 2, 'k': 2, 'c': 1, 's': 1, 'd': 1})