collections模块在内置数据类型(dict list set tuple)的基础上, 还提供了几个额外的数据类型
ChainMap Counter depue defaultdict namedtuple OrderedDict
1. namedtuple 生成可以使用名字来访问元素内容的tuple子集
2. deque 双端队列 可以快速的从另一端追加和退出对象
3. Counter 计算器 主要用来计数
4. OrderedDict 有序字典
5. defaultdict 带有默认值的字典
# 1. namedtuple 生成可以使用名字来访问元素内容的tuple子集 from collections import namedtuple Point = namedtuple("Point",['x','y']) p = Point(1,2) print(p.x) #1 print(p.y) #2 print(p) #Point(x=1, y=2)
# 2. deque 双端队列 可以快速的从另一端追加和退出对象 from collections import deque q = deque(['a','b','c']) q.append('x') q.appendleft('y') print(q)
#3. Counter 计算器 主要用来计数 from collections import Counter c = Counter() for word in ['red', 'blue', 'red', 'green', 'blue', 'blue']: c[word] = c[word] + 1 print(c) # Counter({'blue': 3, 'red': 2, 'green': 1})
# 4. OrderedDict 有序字典 # 使用dict时,Key是无序的。在对dict做迭代时,我们无法确定Key的顺序。 # 如果要保持Key的顺序,可以用OrderedDict: from collections import OrderedDict d = dict(a=1,b=2,c=3) od = OrderedDict(a=1,b=2,c=3) print(od) # # OrderedDict的 Key 是有序的
from collections import OrderedDict od = OrderedDict(a=1,b=2,c=3) od['z'] =222 print(od.keys()) # odict_keys(['a', 'b', 'c', 'z'])
# OrderedDict 可以实现FIFO(先进先出)的dict 当容量超出限制时, 先删除最早添加的key
# 5. defaultdict 带有默认值的字典 # 使用dict时,如果引用的Key不存在,就会抛出KeyError。如果希望key不存在时,返回一个默认值,就可以用defaultdict: from collections import defaultdict dd = defaultdict(lambda: 'WWWW') dd['key1'] = 'abc' print(dd['key1']) # abc print(dd['key12']) # WWWW 不存在 返回默认值 s = 'mississippi' d = collections.defaultdict(int) for i in s: d[i] +=1 print(d) #defaultdict(, {'m': 1, 'i': 4, 's': 4, 'p': 2})