【转】python模块分析之collections(六)

collections是Python内建的一个集合模块,提供了许多有用的集合类。

系列文章

OrderedDict

  • 有序字典,相当于键值对列表;按照创建时的顺序保持不变。

  • 方法:继承了dict结构,有其父类的所有的方法。

import collections
dt = {'a':1,'b':2,'c':3}
o_dict = collections.OrderedDict(dt)
# 通用方法
print(o_dict.keys()) # 返回字典所有的键顺序列表
print(o_dict.items()) # 返回字典键值对元组组成的列表
print(o_dict.values()) # 返回字典所有的值组成的列表
print(o_dict.get('a')) # 返回以键查找的值,没有返回None
print(o_dict.pop('a')) # 以键弹出一个键值对
print(o_dict.clear()) # 清空字典,返回None
print(o_dict.copy()) # 复制一个新的字典
print(o_dict.update({'a':2})) # 更新字典,没有添加新的,有就更新
print(o_dict.setdefault('h', 9)) # 获取一个键的值,如果没有用默认值替代同时加入到字典,有直接返回值
print(o_dict.fromkeys(['a', 'f', 'g'], value=10)) # 创建一个值相同的字典,和原来的字典无关,类方法
# 特殊方法
print(o_dict.popitem(last=True)) # 以元组的方式从右端弹出键值对,last=False从左边弹出
print(o_dict.move_to_end('a', last=True)) # 将一个键值对移到字典的末尾

defaultdict

import collections
dt = {'a':1,'b':2,'c':3}
# 可接受一个数据类型或无参数函数作为初始化
o_dict = collections.defaultdict(list)
o_dict1 = collections.defaultdict(lambda :10)
print(o_dict)
print(o_dict['a'].append(1)) # 默认所有的值都是列表
print(o_dict.get('a')) # 如果键存在,默认值为10
print(o_dict1)

namedtuple

namedtuple是一个函数,它用来创建一个自定义的tuple对象,并且规定了tuple元素的个数,并可以用属性而不是索引来引用tuple的某个元素。

import collections
# 返回一个tuple类型,可以通过自定义的属性访问而不是索引
User = collections.namedtuple('User', ['age','name'])
user = User(19,'xiaoming')
print(user.name)
print(user.age)

deque

  • 双向列表,可以看做一个简单的队列,可以高效地插入和删除数据。支持列表形式的索引取值,不支持切片。
import collections
l = ['a', 'b', 'c']
dq = collections.deque(l)
print(dq.append('c')) # 从右边插入
print(dq.appendleft('c')) # 从左边插入
print(dq.pop()) # 从右边弹出
print(dq.popleft()) # 从左边弹出
print(dq.rotate(3)) # 当参数为正,从右边数n个移到左边;参数为负数时,从左边移动

Counter

  • 一个简单的计数器,统计元素出现的次数,本质也是一个字典。该方法支持各种对字符串的统计;支持加减和交并运算.
import collections
l = 'ffdsgdfgasfsghdgdaf'
c = collections.Counter(l) # 直接生成以字符为键,个数为值的字典,值必须为int
print(c.most_common(3)) # 输出排名前3的元组列表
print(list(c.elements())) # 输出字符列表,从多到少
print(c.subtract('fsdfsfsf')) # 计算相减,得到相减后的字典
print(c)

ChainMap

  • 增删改的操作都只会针对该对象的第一个字典,其余字典不会发生改变,但是如果是查找,则会在多个字典中查找,直到找到第一个出现的key为止。
import collections
dt1 = {'a':1, 'b':2}
dt2 = {'c':1, 'd':2}
c = collections.ChainMap([dt1, dt2]) # 创建一个映射视图将多个字典合在一起
# 特殊的方法
print(c.maps) # 返回所有的字典列表
# 在字典列表头部插入字典,如果其参数为空,则会默认插入一个空字典,并且返回一个改变后的ChainMap对象
print(c.new_child({'a':1}))
  • 作者:天宇之游
  • 出处:http://www.cnblogs.com/cwp-bg/
  • 本文版权归作者和博客园共有,欢迎转载、交流,但未经作者同意必须保留此段声明,且在文章明显位置给出原文链接。

最新文章

  1. TDI - Transport Driver Interface
  2. ARC下的所有权修饰符
  3. 极客DIY:使用树莓派制作一套“NAS+私有云盘+下载机”
  4. shell 中数学计算总结
  5. mysql基础知识(5)--视图
  6. php static 关键字在 函数中的用法
  7. 404 Not Find When using Owin with OAuth
  8. CMD下修改IP地址
  9. centOS(redhat/oracle linux更换语言
  10. JQuery 纵向二级菜单与对齐方式
  11. “大话架构”阿里架构师分享的Java程序员需要突破的技术要点
  12. c#基础,单线程,跨线程访问和线程带参数
  13. matlab知识
  14. 如何用原生js开发一个Chrome扩展程序
  15. Python开发——2.基本数据类型之数字和字符串
  16. [UE4]场景加载界面
  17. Studying GIT
  18. Keras常用层
  19. git 解决冲突问题
  20. Yii2.0 发送文件

热门文章

  1. Symbol特殊用途
  2. tomcat插件使用
  3. 最接近原点的K个点
  4. Scrapy Shell的使用
  5. Ubuntu调节屏幕亮度
  6. Sublime Text3中 less 自动编译成 css 的方法
  7. C#设计模式(1)——简单工厂模式
  8. jenkins检查代码,如没更新停止构建步骤
  9. UESTC - 1999 也许这是唯一能阻止乐爷AK的方法( Just for Fun )(回文树)
  10. python 调用 java代码