前言

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/
  • 本文版权归作者和博客园共有,欢迎转载、交流,但未经作者同意必须保留此段声明,且在文章明显位置给出原文链接。

python内置模块之collections(六)的更多相关文章

  1. python内置模块collections介绍

    目录 python内置模块collections介绍 1.namedtuple 2.deque 3.defaultdict 4.OrderedDict 5.ChainMap 6.Counter 7.小 ...

  2. Python内置模块(re+collections+time等模块)

    Python内置模块(re+collections+time等模块) 1. re模块 import re 在python要想使用正则必须借助于模块 re就是其中之一 1.1 findall功能( re ...

  3. Python开发【第六篇】:模块

    模块,用一砣代码实现了某个功能的代码集合. 类似于函数式编程和面向过程编程,函数式编程则完成一个功能,其他代码用来调用即可,提供了代码的重用性和代码间的耦合.而对于一个复杂的功能来,可能需要多个函数才 ...

  4. python内置模块(4)

    这一部分是python内置模块系列的最后一部分,介绍了一些小巧有用的内置模块. 目录: 1.random 2.shelve 3.getpass 4.zipfile 5.tarfile 6.bisect ...

  5. python内置模块[sys,os,os.path,stat]

    python内置模块[sys,os,os.path,stat] 内置模块是python自带功能,在使用内置模块时,需要遵循 先导入在 使用 一.sys 对象 描述 sys.argv 命令行参数获取,返 ...

  6. python基础篇(六)

    PYTHON基础篇(六) 正则模块re A:正则表达式和re模块案例 B:re模块的内置方法 时间模块time A:时间模块的三种表示方式 B:时间模块的相互转换 随机数模块random A:随机数模 ...

  7. python模块介绍- collections(5)-OrderedDict 有序字典

    1.3.5 OrderedDict 有序字典 OrderedDict是dict的子类,它记住了内容添加的顺序. import collections print 'Regular dictionary ...

  8. python学习笔记(六)文件夹遍历,异常处理

    python学习笔记(六) 文件夹遍历 1.递归遍历 import os allfile = [] def dirList(path): filelist = os.listdir(path) for ...

  9. Python学习笔记(六)

    Python学习笔记(六) Ubuntu重置root密码 Ubuntu 16.4 目录结构 Ubuntu 命令讲解 1. Ubuntu重置root密码 启动系统,显示GRUB选择菜单(如果默认系统启动 ...

随机推荐

  1. BZOJ 4556: [Tjoi2016&Heoi2016]字符串(后缀数组 + 二分答案 + 主席树 + ST表 or 后缀数组 + 暴力)

    题意 一个长为 \(n\) 的字符串 \(s\),和 \(m\) 个询问.每次询问有 \(4\) 个参数分别为 \(a,b,c,d\). 要你告诉它 \(s[a...b]\) 中的所有子串 和 \(s ...

  2. (python爬取小故事网并写入mysql)

    前言: 这是一篇来自整理EVERNOTE的笔记所产生的小博客,实现功能主要为用广度优先算法爬取小故事网,爬满100个链接并写入mysql,虽然CS作为双学位已经修习了三年多了,但不仅理论知识一般,动手 ...

  3. EXTRACT FILES AND IMAGES FROM A SHAREPOINT CONTENT DATABASE

    If you ever had the problem where you need to extract files from a SharePoint Content Database or no ...

  4. 几个面试经典算法题Java解答

    题目一: public class testClockwiseOutput { //顺时针打印一个矩阵 @Test public void test(){ int[][] num = new int[ ...

  5. UVA 1394 And Then There Was One / Gym 101415A And Then There Was One / UVAlive 3882 And Then There Was One / POJ 3517 And Then There Was One / Aizu 1275 And Then There Was One (动态规划,思维题)

    UVA 1394 And Then There Was One / Gym 101415A And Then There Was One / UVAlive 3882 And Then There W ...

  6. 【CH5105】cookies 贪心+DP

    通过邻项交换法可知,怨气值大的孩子分得的饼干数也应该多(否则交换之后得到的解更优). 观察目标函数的性质,可知目标函数本身是由孩子饼干数的相对大小得到,因此此题中关注的是相对大小. 状态设计:\(dp ...

  7. 使用C#实现实体类和XML相互转换

    一.实体类转换成XML 将实体类转换成XML需要使用XmlSerializer类的Serialize方法,将实体类序列化 public static string XmlSerialize<T& ...

  8. bug6 项目检出JRE问题(Unbound classpath container: 'JRE System Library [JavaSE-1.7]' in project 'idweb')

    项目从SVN检出到工作空间后报了很多错误,其中很明显就是一些jar的问题,没有相关的jar或版本问题,看到最后的错误Unbound classpath Container: 'JRE System L ...

  9. 2018.9青岛网络预选赛(B)

    传送门:Problem(B) https://www.cnblogs.com/violet-acmer/p/9664805.html 参考资料: https://blog.csdn.net/qq_40 ...

  10. java8中的stream().filter()的使用和Optional()

    转: https://www.cnblogs.com/yimiyan/p/5992440.html Optional: https://www.cnblogs.com/zhangboyu/p/7580 ...