Python collections系列之计数器】的更多相关文章

计数器(counter) Counter是对字典(无序)类型的补充,用于追踪值的出现次数. 使用counter需要导入 collections 类 ps:具备字典的所有功能 + 自己的功能 1.创建一个计数器 >>> import collections >>> obj = collections.Counter('aaabbccsdfsdfdfsdfsdf') 2.查看计数器变量 >>> print(obj) Counter({'d': 5, 'f'…
有序字典(orderedDict ) orderdDict是对字典类型的补充,他记住了字典元素添加的顺序 1.创建一个有序字典 import collections dic = collections.OrderedDict() dic['k1'] = 'v1' dic['k2'] = 'v2' dic['k3'] = 'v3' 2.查看有序字典 print(dic) 输出结果: OrderedDict([('k1', 'v1'), ('k2', 'v2'), ('k3', 'v3')]) 3.…
单向队列(deque) 单项队列(先进先出 FIFO ) 1.创建单向队列 import queue q = queue.Queue() q.put(') q.put('evescn') 2.查看单向队列 # 单向队列是先进先出,要查看单向队列,需使用get获取单向队列的值 print(q.get()) print(q.get()) 输出结果: 123 evescn 3.单向队列和双向队列的区别 # 双向队列: 调用:import collections collections.deque()…
双向队列(deque) 一个线程安全的双向队列 1.创建一个双向队列 import collections d = collections.deque() d.append(') d.appendleft(') d.appendleft('a') d.appendleft(') 2.查看双向队列 print(d) 输出结果: deque([']) 3.查看双向队列的方法 >>> dir(d) ['__class__', '__copy__', '__delattr__', '__deli…
可命名元组(namedtuple)  根据nametuple可以创建一个包含tuple所有功能以及其他功能的类 1.创建一个坐标类 import collections # 创建类, defaultdict,坐标中会使用 MytupleClass = collections.namedtuple('MytupleClass',['x', 'y', 'z']) obj = MytupleClass(11, 22, 33) 2.查询类中的x,y,z坐标 # 默认情况下元组只能使用索引进行访问,通过创…
默认字典(defaultdict)  defaultdict是对字典的类型的补充,它默认给字典的值设置了一个类型. 1.创建默认字典 import collections dic = collections.defaultdict(list) # 设置dic的值类型为list dic['k1'].append('evescn') 2.查看默认字典 print(dic) 输出结果: defaultdict(<class 'list'>, {'k1': ['evescn']}) 3.查看默认字典的…
global log 127.0.0.1 local2 daemon maxconn log 127.0.0.1 local2 info defaults log global mode http timeout connect 5000ms timeout client 50000ms timeout server 50000ms option dontlognull listen stats : stats enable stats uri /admin stats auth admin:…
 一.collections系列: collections其实是python的标准库,也就是python的一个内置模块,因此使用之前导入一下collections模块即可,collections在python原有的数据类型str(字符串), int(数值), list(列表) tuple(元组), dict(字典)的基础之上增加一些其他的数据类型即方法,具体如下: 1.Counter(dict):计数器,扩展的字典的方法,对指定数据的字串做统计出现的次数,结果是一个元组,如: import co…
1>set集合:是一个无序且不重复的元素集合:访问速度快,解决了重复的问题: s2 = set(["che","liu","haha"]) add():添加元素: difference():将前一个集合与后者的不同建立为一个新的集合:没有改变当前集合,生成了新的集合: difference_update():从集合中去除指定的元素:改变了当前集合,不生成新的集合: intersection():取交集,生成一个新的集合: intersect…
Python collections模块总结 除了我们使用的那些基础的数据结构,还有包括其它的一些模块提供的数据结构,有时甚至比基础的数据结构还要好用. collections ChainMap 这是一个为多个映射创建单一视图的类字典类型,也就是说,它同样具有字典类型的方法,它比基础数据结构中的字典的创建和多次更新要快,需要注意的是,增删改的操作都只会针对该对象的第一个字典,其余字典不会发生改变,但是如果是查找,则会在多个字典中查找,直到找到第一个出现的key为止. 特有方法 解释 maps 返…