1.有序字典: 在Python3.6之后字典自动变成有序了,可是3.6版本以前的还须要用到html
OrderedDict: 有序字典,增长的键值对会依次在后面添加app
from collections import OrderedDict od = OrderedDict([("a",1),("b",2),("c",3)]) print(od) #OrderedDict([('a', 1), ('b', 2), ('c', 3)]) od["d"]= 4 od["e"]= 5 print(od) #OrderedDict([('a', 1), ('b', 2), ('c', 3), ('d', 4), ('e', 5)])
2.带默认值的字典 defaultdictspa
新增长的键,默认值是相同的,可对默认值(value)进行更改,操做与字典操做同样code
from collections import defaultdict values = [11, 22, 33,44,55,66,77,88,99,90] dic = defaultdict(list) for i in values: if i > 66: dic["k1"].append(i) else: dic["k2"].append(i) print(dic) #defaultdict(<class 'list'>, {'k2': [11, 22, 33, 44, 55, 66], 'k1': [77, 88, 99, 90]})
3.Counter 计数器htm
Counter类的目的是用来跟踪值出现的次数。它是一个无序的容器类型,以字典的键值对形式存储,其中元素做为key,其计数做为value。计数值能够是任意的Interger(包括0和负数)。Counter类和其余语言的bags或multisets很类似。对象
c = Counter('abcdeabcdabcaba') print c 输出:Counter({'a': 5, 'b': 4, 'c': 3, 'd': 2, 'e': 1})
详细:http://www.cnblogs.com/Eva-J/articles/7291842.htmlblog
4.deque:双端队列 能够快速的从另一侧追加或者退出对象队列
做用:为了高效的实现插入和删除操做的双向列表,适合队列和栈get
from collections import deque
q = deque(["a","b","c"])
q.append("x") #在列表尾增长
q.appendleft("y") #在列表首追加
print(q) #deque(['y', 'a', 'b', 'c', 'x'])
print(q.pop()) #x
print(q.popleft()) #y
5.namedtuple 可命名元组io
# from collections import namedtuple # birth = namedtuple('Struct_time',['year','month','day']) # b1 = birth(2018,9,5) # print(type(b1)) # print(b1.year) # print(b1.month) # print(b1.day) # print(b1) # 可命名元组很是相似一个只有属性没有方法的类 # ['year','month','day']是对象属性名 # Struct_time是类 的名字 # 这个类最大的特色就是一旦实例化 不能修改属性的值