python collections.Counter()函数
‘’‘统计字符串中字符出现的个数,
以字符为key
以数量为value’’’
import collections
a = collections.Counter('bbaaccdd')
b = collections.Counter('abcd')
print(a)
print(b)
print(a+b)
结果
Counter({'b': 2, 'a': 2, 'c': 2, 'd': 2})
Counter({'a': 1, 'b': 1, 'c': 1, 'd': 1})
Counter({'b': 3, 'a': 3, 'c': 3, 'd': 3})
import collections
a = collections.Counter('bbaaccdd')
b = collections.Counter('abcd')
print((a + b).most_common(2))
#返回一个列表。most_common()中可以添加数字,
即为在排序后输出前几个数据,不添加数据则输出全部
结果
[('b', 3), ('a', 3)]
c = collections.Counter('aabbcccddde')
c
结果:
Counter({'a': 2, 'b': 2, 'c': 3, 'd': 3, 'e': 1})
print(a+b+c)
结果:Counter({'c': 6, 'd': 6, 'b': 5, 'a': 5, 'e': 1})
a = [1,4,2,3,2,3,4,2]
from collections import Counter
print (Counter(a))
结果:
Counter({2: 3, 4: 2, 3: 2, 1: 1})
判断是否包含某元素,可以转化为dict然后通过dict判断,Counter也带有函数可以判断:
c = Counter(['eggs', 'ham'])
c['bacon'] # 不存在就返回0
#0
删除元素:
c['sausage'] = 0 # counter entry with a zero count
del c['sausage']
获得所有元素:
c = Counter(a=4, b=2, c=0, d=-2)
list(c.elements())
#['a', 'a', 'a', 'a', 'b', 'b']
查看最常见出现的k个元素:
Counter('abracadabra').most_common(3)
#[('a', 5), ('r', 2), ('b', 2)]
Counter更新:
c = Counter(a=3, b=1)
d = Counter(a=1, b=2)
c + d # 相加
#Counter({'a': 4, 'b': 3})
c - d # 相减,如果小于等于0,删去
#Counter({'a': 2})
c & d # 求最小
#Counter({'a': 1, 'b': 1})
c | d # 求最大
#Counter({'a': 3, 'b': 2})