collection模块

介绍

在内置数据类型(dict、list、set、tuple)的基础上,collections模块还提供了几个额外的数据类型:Counter、deque、defaultdict、namedtuple和OrderedDict等。

# 1.namedtuple: 生成可以使用名字来访问元素内容的tuple

# 2.deque: 双端队列,可以快速的从另外一侧追加和推出对象

# 3.Counter: 计数器,主要用来计数

# 4.OrderedDict: 有序字典

# 5.defaultdict: 带有默认值的字典

namedtuple具名元组

命名的元组,意味给元组中的每个位置赋予含义,意味着代码可读性更强,namedtuple可以在任何常规元素使用的地方使用,而且它可以通过名称来获取字段信息而不仅仅是通过位置索引
namedtuple是一个函数,它用来创建一个自定义的tuple对象,并且规定了tuple元素的个数,并可以用属性而不是索引来引用tuple的某个元素

语法
# tuple对象名 = namedtuple(名称, 属性)  
第一个参数是字符串类型描述第二个参数属性用于什么
第二个参数是可迭代对象用于表明要存的元素属性,如果是字符串用空格隔开表明各元素属性
# 变量名 = tuple对象名(各元素) 元素的个数必须跟namedtuple第二个参数里面的属性数量一致

获取元素的方法:
# 所有值:直接使用变量名
# 单个值:变量量名.属性名

# 例子
from collections import namedtuple
point = namedtuple('坐标',['x','y','z'])
point = namedtuple('坐标','x y z')
p = point(1,2,5)
print(p)  # 坐标(x=1, y=2, z=5)
print(p.x)  # 1
print(p.y)  # 2
print(p.z)  # 3

deque双端队列

使用list存储数据时,按索引访问元素很快,但是插入和删除元素就很慢了,因为list是线性存储,数据量大的时候,插入和删除效率很低。

deque是为了高效实现插入和删除操作的双向列表,适合用于队列和栈

deque除了实现list的append()和pop()外,还支持appendleft()和popleft(),这样就可以非常高效地往头部添加或删除元素

# 例子
from collections import deque
q = deque(['a','b','c'])
q.append(1)
print(q)  # deque(['a', 'b', 'c', 1])
q.appendleft(2)
print(q)  # deque([2, 'a', 'b', 'c', 1])
q.insert(0,'哈哈哈')  # deque(['哈哈哈', 2, 'a', 'b', 'c', 1])
# 特殊点:双端队列可以根据索引在任意位置插值

print(q.pop())  # 1
print(q.popleft())  # 哈哈哈'

Counter计数器

counter可以支持方便、快速的计数,例如,
from collections import *

cnt = Counter()
wordList = ["a","b","c","c","a","a"]
for word in wordList:
    cnt[word] += 1
print(cnt)

#输出
Counter({'a': 3, 'c': 2, 'b': 1})

 

posted @ 2019-07-18 18:32  浅墨灬清风  阅读(157)  评论(0编辑  收藏  举报