博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Python基础 collections模块
阅读量:4495 次
发布时间:2019-06-08

本文共 1859 字,大约阅读时间需要 6 分钟。

collections模块

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

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

2.deque: 双端队列,可以快速的从另外一侧追加和推出对象
3.Counter: 计数器,主要用来计数
4.OrderedDict: 有序字典
5.defaultdict: 带有默认值的字典

nametuple:

1 """ 2 namedtuple是一个函数,它用来创建一个自定义的tuple对象,并且规定了tuple元素的个数,并可以用属性而不是索引来引用tuple的某个元素。 3  4 这样一来,我们用namedtuple可以很方便地定义一种数据类型,它具备tuple的不变性,又可以根据属性来引用,使用十分方便。 5 """ 6 from collections import namedtuple 7 Point= namedtuple("Point",['x','y']) 8 p=Point(1,2) 9 print(p.x,p.y)10 print(isinstance(p,Point))11 print(isinstance(p,tuple))
View Code

deque:

1 """ 2 使用list存储数据时,按索引访问元素很快,但是插入和删除元素就很慢了,因为list是线性存储,数据量大的时候,插入和删除效率很低。 3  4 deque是为了高效实现插入和删除操作的双向列表,适合用于队列和栈: 5 deque除了实现list的append()和pop()外,还支持appendleft()和popleft(),这样就可以非常高效地往头部添加或删除元素。 6 """ 7 from collections import deque 8 q=deque(['a','b','c']) 9 q.append('x')10 q.appendleft('z')11 print(q)12 q.popleft()13 print(q)
View Code

Counter:

1 """ 2 Counter是一个简单的计数器,例如,统计字符出现的个数: 3 Counter实际上也是dict的一个子类 4 """ 5  6 from collections import Counter 7 c=Counter() 8 for ch in "acceptable": 9     c[ch]=c[ch]+110 print(c)
View Code

OrderedDict:

1 """ 2 使用dict时,Key是无序的。在对dict做迭代时,我们无法确定Key的顺序。 3  4 如果要保持Key的顺序,可以用OrderedDict: 5 OrderedDict的Key会按照插入的顺序排列,不是Key本身排序: 6  7 """ 8 from collections import OrderedDict 9 d=dict([("a",1),("b",2),("c",3)])10 print(d)11 od=OrderedDict([("a",1),("b",2),("c",3)])12 print(od)13 14 od1=OrderedDict()15 od1['z']=116 od1['y']=217 od1['x']=318 print(od1.keys())19 20 # OrderedDict可以实现一个FIFO(先进先出)的dict,当容量超出限制时,先删除最早添加的Key:
View Code

defaultdict:

1 """2 使用dict时,如果引用的Key不存在,就会抛出KeyError。如果希望key不存在时,返回一个默认值,就可以用defaultdict:3 """4 from collections import defaultdict5 dd=defaultdict(lambda:"N/A")6 dd['key1']='abc'7 print(dd['key2'])
View Code

 

转载于:https://www.cnblogs.com/zero1230/p/9108035.html

你可能感兴趣的文章
常见前端开发的题目,可能对你有用
查看>>
BeautifulSoap库入门
查看>>
乐观锁与悲观锁
查看>>
Codeforces Round #328 (Div. 2)D. Super M 虚树直径
查看>>
Java判断是否为移动端
查看>>
chromedriver下载链接以及对应版本
查看>>
[SimplePlayer] 6. 音频同步
查看>>
把一个SVN项目的目录结构 导入到另外一个空白的SVN项目里
查看>>
Android之Adapter用法总结-(转)
查看>>
总结列表显示ListView知识点
查看>>
android 教程实例系列
查看>>
lucene笔记
查看>>
tomcat无法正常shutdown
查看>>
zookeeper + dubbo 搭建
查看>>
根据前序遍历和中序遍历求出二叉树并打印
查看>>
UOJ356 [JOI2017春季合宿] Port Facility 【启发式合并】【堆】【并查集】
查看>>
Delphi的命令行编译命令
查看>>
BZOJ 1901 Zju2112 Dynamic Rankings 题解
查看>>
C++虚析构函数
查看>>
《玩转.NET Micro Framework 移植-基于STM32F10x处理器》--微软中国.NET Micro Framework项目组工程师所作之序...
查看>>