python的collection模块

xiaoxiao2021-02-28  62

python的collection模块

collections模块在内置的数据类型,比如:int、str、list、dict等基础之上额外提供了几种数据类型。

1.namedtuple(): 生成可以使用名字来访问元素内容的tuple子类2.deque: 双端队列,可以快速的从另外一侧追加和推出对象3.Counter: 计数器,主要用来计数4.OrderedDict: 有序字典5.defaultdict: 带有默认值的字典

 

一:namedtuple(),可命名元组。

tuple是一个不可变的集合,namedtuple是一个函数,她用来构建一个自定义的tuple对象,并且规定了tuple元素的个数,可通过属性而不是索引来引用tuple的某个元素。我们可以通过namedtuple很方便的自定义一个数据类型,它具有tuple 的不变属性又可以根据属性来引用。

from collections import namedtuplepiont=namedtuple('piont',['x','y'])p=piont(2,1)print(p)print("x =",p.x)print("Y =",p.y)>>>isinstance(p,piont)True>>>isinstance(p,tuple)True类似的创建一个圆,通过坐标,半径r。用namedtuple构建Cirle=namedtup(‘Circle’,['x','y','r'])2、有序字典(orderedDict )dict中key是无序的,在做迭代时,无法确认key的顺序。orderdDict是对字典类型的补充,他记住了字典元素添加的顺序 from collections import OrderedDictod=OrderedDict([('a',1),('z',2),('c',3)])// 有序字典顺序是插入进去的顺序排列的print(od)d=dict([('a',1),('z',2),('c',3)]) //字典是无序的,key的顺序是变化的print(d) 3、默认字典(defaultdict)defaultdict是对字典的类型的补充,他默认给字典的值设置了一个类型。 我们都知道,在使用Python原生的数据结构dict的时候,如果用 d[key] 这样的方式访问, 当指定的key不存在时,是会抛出KeyError异常的。但是,如果使用defaultdict,只要你传入一个默认的工厂方法,那么请求一个不存在的key时, 便会调用这个工厂方法使用其结果来作为这个key的默认值。 4、计数器CounterCounter是对字典类型的补充,用于追踪值的出现次数。具备字典的所有功能+自己的功能 from collections import Counterc=Counter(['11','22','11','33','11','44','55'])c2=Counter("abcdefdasfdsafaf")print(c)print(c2) most_common(self, n=None),数量从大到小排列,获取前N个元素。 elements(self) 计数器中的所有元素。注:此处非所有元素集合,而是包含所有元素集合的迭代器sorted(c.elements()) update(self,iterable=None,**keds):更新计数器,其实是增加计数器,如果没有则新建。 c.update('witch') subtract(self, iterable=None, **kwds):相减,原来的计数器中的每一个元素的数量减去后添加的元素的数量c.subtract('witch')
转载请注明原文地址: https://www.6miu.com/read-2596315.html

最新回复(0)