collections容器数据类型是对基本数据类型的补充,简单介绍下计数器、有序字典、默认字典、可命名元祖、队列。

计数器(Counter)

Counter是对字典类型的补充,用于追踪值得出现次数

class Counter(dict)

import collections

obj = collections.Counter('asiwenaohweiatgwho')
print(obj)
    def most_common()
# 返回一个列表
    def elements()
# elements用来循环Counter元素 # 取到keys
for item in obj.elements():
print(item) # 取到key和value
for k,v in obj.items():
print(k,v) # 循环elements -> 得到原始数据
# 循环obj -> 得到处理完的数据
    def update()
# 更新Counter obj.update(['eric',11,11])
更新计数器,如果原来没有,则新建,如果有则加1
    def subtract()
# 减少,可以为负

有序字典(OrderedDict)

对字典类型的补充,记住了字典元素添加的顺序

class OrderedDict(dict)

dic = collections.OrderedDict()
# 字典 dic = {'k1':'v1','k2':'v2'}
# 列表 li = ['k1','k2']
# for i in li:
# print(dic[i])
#!/usr/bin/env python3

import collections

# dic = dict()
dic = collections.OrderedDict()
dic['k1'] = 'v1'
dic['k2'] = 'v2'
dic['k3'] = 'v3' print(dic)
    def move_to_end()
# 把一个已存在的元素移到队尾 dic.move_to_end('k1')
    def popitem()
# 删除并返回,总是按照LIFO顺序,栈 # 按照后进先出的顺序,栈
dic.popitem() def pop()
# 删除指定的k,并返回v dic.pop('k2')
# 有返回值v2
dic['k4'] = None
dic.setdefault('k4') # 这两句效果等同 dic.update({'k1':'xx','k2':'yy'})

默认字典(defaultdict)

定义一个字典,让字典的值默认是个什么类型

dic = collections.defaultdict(list)
dic['k1'].append('alex')
print(dic)
from collections import defaultdict
values = [11,22,33,44,55,66,77,88,99]
my_dict = defaultdict(list) for value in values:
if value > 66:
my_dict['k1'].append(value)
else:
my_dict['k2'].append(value)

可命名元祖(namedtuple)

默认元祖是通过索引去访问,可命名元祖可以通过命名参数去访问

创建可命名元祖,需要先创建类,通过类再去创建可命名元祖

import collections

#先去创建类
MytupleClass = collections.namedtuple('MytupleClass',['x','y','z']) # 创建MytupleClass类
dir(MytupleClass) obj = MytupleClass(11,22,33)
print(obj.x)
print(obj.y)
print(obj.z) obj._asdict() #返回一个有序字典OrderedDict

队列

python提供了两种队列:单向队列和双向队列

双向队列 deque

import collections
dq = collections.deque() # 创建双向队列 dq.append()
dq.appendleft()
dq.clear()
dq.count()
dq.extend()
dq.extendleft()
dq.pop() #从右边取
dq.popleft() # 从左边取
dq.remove() #从左往右删除
dq.reverse()
dq.rotate(n) #轮训,从左往右轮询n个值,如果n为负数,则往左轮询

单向队列 先进先出FIFO

# epoll
# 单向队列,不在collections模块中,在queue中
import queue
q = queue.Queue(N) #创建一个长队为N的单向队列,如果N省略,则无穷大
q.qsize() #返回队列的长度
q.empty() #如果队列为空,则返回True,否则返回False
q.full() #如果队列已满,则返回True,否则返回Faluse
q.put('123') #put一个元素到队列尾部
q.get() #从队列头部移除并返回一个元素,FIFO

最新文章

  1. view类的setVisibility
  2. zoj1260 king
  3. iOS开发中深入理解CADisplayLink和NSTimer
  4. ABAP自定义类的构造方法
  5. 整合spring roo,maven,mybatis,spring-flex,blazeds,mysql
  6. android对应版本号
  7. 提高Delphi的编译速度(bpl和bcp)
  8. DataTables学习:从最基本的入门静态页面,使用ajax调用Json本地数据源实现前端开发深入学习,根据后台数据接口替换掉本地的json本地数据,以及报错的处理地方,8个例子(显示行附加信息,回调使用api,动态显示和隐藏列...),详细教程
  9. 这辈子只能碰到一次! 记一次SSL无故被撤消!
  10. 笔记:Maven 聚合和继承
  11. 201621123040《Java程序设计》第八周学习总结
  12. 每CPU变量
  13. Spring cloud定义学习
  14. Docker日志管理--docker部署安装ELK (十一)--技术流ken
  15. DOM简单梳理
  16. App 打包
  17. 浅谈UML中常用的几种图——类图
  18. chown nagios:nagios -R /var/lib/php/
  19. TFS 2017 持续集成速记
  20. 记一次Springboot启动异常

热门文章

  1. <原>ASP.NET 学习笔记之应养成的良好习惯
  2. APP应用的发展趋势
  3. 异常IllegalStateException终于解决了
  4. 制作U盘启动盘(以CentOS6.3为例)
  5. ##DAY12 UITableViewCell自定义
  6. HDU 5584 LCM Walk(数学题)
  7. C++小知识之Map用法
  8. ThinkPHP第二十二天(表单令牌、相对路径、扩展配置载入、$Think获取系统变量、$_SERVER('HTTP_REFERER')前页地址)
  9. AAU账号分割
  10. Spring Boot的一个测试用例