Python3之内建模块collections
collections是python内建的一个集合模块,提供了许多有用的集合类。
namedtuple
我们知道tuple可以表示不可变集合,例如,一个点的二维坐标可以表示成
- >>> p=(1,2)
但是,看到(1, 2)
,很难看出这个tuple
是用来表示一个坐标的。
定义一个class又小题大做了,这时,namedtuple
就派上了用场:
- >>> from collections import namedtuple
- >>> Point=namedtuple('Point',['x','y'])
- >>> p=Point(1,2)
- >>> p.x
- 1
- >>> p.y
- 2
namedtuple
是一个函数,它用来创建一个自定义的tuple
对象,并且规定了tuple
元素的个数,并可以用属性而不是索引来引用tuple
的某个元素。
这样一来,我们用namedtuple
可以很方便地定义一种数据类型,它具备tuple的不变性,又可以根据属性来引用,使用十分方便。
可以验证创建的Point
对象是tuple
的一种子类:
- >>> isinstance(p,Point)
- True
- >>> isinstance(p,tuple)
- True
类似的,如果用坐标和半径表示一个圆,也可以用namedtuple定义
- >>> Circle=namedtuple('Circle',['x','y','r'])
- >>> c=Circle(1,2,1)
deque
使用list存储数据时,按索引访问元素很快,但插入和删除元素就慢了,因为list是线性存储,数据量大的时候,插入和删除效率很低。
deque是为了高效实现插入和删除操作的双向列表,适合用于队列和栈:
- >>> from collections import deque
- >>> q=deque(['a','b','c'])
- >>> q.append('x')
- >>> q.appendleft('y')
- >>> q
- deque(['y', 'a', 'b', 'c', 'x'])
deque除了实现list的append()和pop()外,还支持appendleft()和popleft(),这样就可以非常搞笑地往头部添加或者删除元素。
defaultdict
使用dict时,如果引用的Key不存在,就会抛出KeyError。如果希望key不存在时,返回一个默认值,就可以用defaultdict
- >>> from collections import defaultdict
- >>> dd=defaultdict(lambda:'N/A')
- >>> dd['key1']='abc'
- #key1存储在返回
- >>> dd['key1']
- 'abc'
- #key2不存在返回自定义的默认值
- >>> dd['key2']
- 'N/A'
注意默认值是调用函数返回的,而函数在创建defaultdict
对象时传入。
除了在Key不存在时返回默认值,defaultdict
的其他行为跟dict
是完全一样的。
OrderedDict
使用dict时,Key是无序的。在对dict做迭代时,我们无法确定Key的顺序
如果要保持Key的顺序,可以使用OrderedDict
- >>> from collections import OrderedDict
- >>> d=dict([('a',1),('b',2),('c',3)])
- #d是无序的
- >>> d
- {'a': 1, 'b': 2, 'c': 3}
- >>> od=OrderedDict([('a',1),('b',2),('c',3)])
- #od是有序的
- >>> od
- OrderedDict([('a', 1), ('b', 2), ('c', 3)])
注意,OrderedDict的Key会按照插入的顺序排序,不是Key本身排序
- >>> od=OrderedDict()
- >>> od['z']=1
- >>> od['y']=2
- >>> od['x']=3
- >>> od.keys()
- odict_keys(['z', 'y', 'x'])
- #按照插入的Key的顺序返回
- >>> list(od.keys())
- ['z', 'y', 'x']
ChinaMap
ChainMap
可以把一组dict
串起来并组成一个逻辑上的dict
。ChainMap
本身也是一个dict,但是查找的时候,会按照顺序在内部的dict依次查找。
什么时候使用ChainMap
最合适?举个例子:应用程序往往都需要传入参数,参数可以通过命令行传入,可以通过环境变量传入,还可以有默认参数。我们可以用ChainMap
实现参数的优 先级查找,即先查命令行参数,如果没有传入,再查环境变量,如果没有,就使用默认参数。
下面的代码演示了如何查找user
和color
这两个参数:
use_chinamap.py
- #!/usr/bin/env python3
- # -*- coding: utf-8 -*-
- from collections import ChainMap
- import os, argparse
- defaults = {
- 'color': 'red',
- 'user': 'guest'
- }
- parser = argparse.ArgumentParser()
- parser.add_argument('-u', '--user')
- parser.add_argument('-c', '--color')
- namespace = parser.parse_args()
- command_line_args = { k: v for k, v in vars(namespace).items() if v }
- combined = ChainMap(command_line_args, os.environ, defaults)
- print('color=%s' % combined['color'])
- print('user=%s' % combined['user'])
运行,没有任何参数时,打印默认参数
- #python3 use_chainmap.py
- color=red
- user=guest
当传入命令行参数时,有限使用命令行参数
- python3 use_chainmap.py -u Zhangsan
- color=red
- user=Zhangsan
同时传入命令行参数和环境变量,命令行参数优先级较高
- user=admin color=green python3 use_chainmap.py -u Zhangsan
- color=green
- user=Zhangsan
Counter
Counter是一个简单的计数器,例如,统计字符出现的个数
- >>> from collections import Counter
- >>> c=Counter()
- >>> for ch in 'prohramming':
- ... c[ch]=c[ch]+1
- ...
- >>>
- >>> c
- Counter({'r': 2, 'm': 2, 'p': 1, 'o': 1, 'h': 1, 'a': 1, 'i': 1, 'n': 1, 'g': 1})
Counter
实际上也是dict
的一个子类,上面的结果可以看出,字符'g'
、'm'
、'r'
各出现了两次,其他字符各出现了一次。
Python3之内建模块collections的更多相关文章
- Python3之内建模块itertools
python的内建模块itertools提供了非常有用的用于操作迭代对象的函数 首先,我们看看itertools提供的几个无限迭代器 >>> import itertools > ...
- Python3之内建模块datetime
datetime datetime是python处理日期和时间的标准库 获取当前日期和时间 >>> from datetime import datetime #获取当前的datet ...
- Python3之内建模块hashlib
摘要算法简介 Python的hashlib提供了常见的摘要算法,如MD5,SHA1等等. 什么是摘要算法呢?摘要算法又称哈希算法.散列算法.它通过一个函数,把任意长度的数据转换为一个长度固定的数据串( ...
- Python3之内建模块base64
Base64是一种用64个字符来表示任意二进制数据的方法. 用记事本打开exe.jpg.pdf这些文件时,我们都会看到一大堆乱码,因为二进制文件包含很多无法显示和打印的字符,所以,如果要让记事本这样的 ...
- Python内建模块--collections
python内建模块--collections collections是Python内建的一个集合模块,提供了许多有用的集合类. namedtuple 我们知道tuple可以表示不变集合,例如,一个点 ...
- python常用内建模块 collections,bs64,struct,hashlib,itertools,contextlib,xml
# 2 collections 是Python内建的一个集合模块,提供了许多有用的集合类. # 2.1 namedtuple #tuple可以表示不变集合,例如,一个点的二维坐标就可以表示成: p ...
- Python3 内建模块 hashlib、itertools、HTMLParser、urllib
Python的hashlib提供了常见的摘要算法,如MD5,SHA1等等. 什么是摘要算法呢?摘要算法又称哈希算法.散列算法.它通过一个函数,把任意长度的数据转换为一个长度固定的数据串(通常用16进制 ...
- Python3 内建模块 datetime/collections/base64/struct
datetime 我们先看如何获取当前日期和时间: >>> from datetime import datetime >>> now = datetime.now ...
- 四十二 常用内建模块 collections
collections是Python内建的一个集合模块,提供了许多有用的集合类. namedtuple 我们知道tuple可以表示不变集合,例如,一个点的二维坐标就可以表示成: >>> ...
随机推荐
- 2019 icpc 徐州 解题报告
A.Cat 题库链接 给定区间[l,r],求一个最长子区间,使得区间异或和小于等于s,(结论)偶数和偶数后三个数的异或和等于0 #include <bits/stdc++.h> using ...
- RookeyFrame 附件 上传附件
上传附件可允许的格式: 位置:Rookey.Frame.Web\Config\upload.xml 节点:Attachment -> allowType
- 《挑战30天C++入门极限》在c/c++中利用数组名作为函数参数传递排序和用指针进行排序的例子。
在c/c++中利用数组名作为函数参数传递排序和用指针进行排序的例子. 以下两个例子要非常注意,函数传递的不是数组中数组元素的真实值而是数组在内存中的实际地址. #include <std ...
- Redis企业实战的几个坑
一.前言 小伙伴们对Redis应该不陌生,Redis是系统必备的分布式缓存中间件,主要用来解决高并发下分担DB资源的负载,从而提升系统吞吐量. Redis支持多种数据类型,String(字符串).li ...
- Java 中List集合中自定义排序
/* 集合框架的工具类. Collections:集合框架的工具类.里面定义的都是静态方法. Collections和Collection有什么区别? Collection是集合框架中的一个顶层接口, ...
- tecplot三维模型绘制二维切片流线
原视频下载地址链接: https://pan.baidu.com/s/1csugHK 密码: xrni
- 深入理解volatile原理与使用
volatile:称之为轻量级锁,被volatile修饰的变量,在线程之间是可见的. 可见:一个线程修改了这个变量的值,在另一个线程中能够读取到这个修改后的值. synchronized除了线程之间互 ...
- service mesh,linkerd,sidecar,apigateway
对于大规模部署微服务(微服务数>1000).内部服务异构程度高(交互协议/开发语言类型>5)的场景,使用service mesh是合适的.但是,可能大部分开发者面临的微服务和内部架构异构复 ...
- Java学习之"Hello World"
好像学习每个程序敲的第一个代码都是"Hello World",而学习Java也不例外,这篇博客就讲一下我学习Java的第一个程序HelloWorld.java 程序代码: publ ...
- 【软工实践】团队项目Snug-需求分析报告
组长博客链接 博客链接 团队项目整体计划安排 阶段序列 阶段时间 主要阶段任务 完成情况 第一阶段 9.6 团队成立 已完成 第二阶段 9.6-9.13 课题选择 已完成 第三阶段 9.13-9.18 ...