电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

Python中內(nèi)建模塊collections如何使用

瀏覽:101日期:2022-07-24 11:05:31

collections是Python內(nèi)建的一個(gè)集合模塊,提供了許多有用的集合類。

這里舉幾個(gè)例子:

namedtuple

我們知道tuple可以表示不變集合,例如,一個(gè)點(diǎn)的二維坐標(biāo)就可以表示成:

>>> p = (1, 2)

但是,看到(1, 2),很難看出這個(gè)tuple是用來(lái)表示一個(gè)坐標(biāo)的。

定義一個(gè)class又小題大做了,這時(shí),namedtuple就派上了用場(chǎng):

>>> from collections import namedtuple>>> Point = namedtuple(’Point’, [’x’, ’y’])>>> p = Point(1, 2)>>> p.x1>>> p.y2

namedtuple是一個(gè)函數(shù),它用來(lái)創(chuàng)建一個(gè)自定義的tuple對(duì)象,并且規(guī)定了tuple元素的個(gè)數(shù),并可以用屬性而不是索引來(lái)引用tuple的某個(gè)元素。

這樣一來(lái),我們用namedtuple可以很方便地定義一種數(shù)據(jù)類型,它具備tuple的不變性,又可以根據(jù)屬性來(lái)引用,使用十分方便。

可以驗(yàn)證創(chuàng)建的Point對(duì)象是tuple的一種子類:

>>> isinstance(p, Point)True>>> isinstance(p, tuple)True

類似的,如果要用坐標(biāo)和半徑表示一個(gè)圓,也可以用namedtuple定義:

# namedtuple(’名稱’, [屬性list]):Circle = namedtuple(’Circle’, [’x’, ’y’, ’r’])

deque

使用list存儲(chǔ)數(shù)據(jù)時(shí),按索引訪問(wèn)元素很快,但是插入和刪除元素就很慢了,因?yàn)閘ist是線性存儲(chǔ),數(shù)據(jù)量大的時(shí)候,插入和刪除效率很低。

deque是為了高效實(shí)現(xiàn)插入和刪除操作的雙向列表,適合用于隊(duì)列和棧:

>>> from collections import deque>>> q = deque([’a’, ’b’, ’c’])>>> q.append(’x’)>>> q.appendleft(’y’)>>> qdeque([’y’, ’a’, ’b’, ’c’, ’x’])

deque除了實(shí)現(xiàn)list的append()和pop()外,還支持appendleft()和popleft(),這樣就可以非常高效地往頭部添加或刪除元素。

defaultdict

使用dict時(shí),如果引用的Key不存在,就會(huì)拋出KeyError。如果希望key不存在時(shí),返回一個(gè)默認(rèn)值,就可以用defaultdict:

>>> from collections import defaultdict>>> dd = defaultdict(lambda: ’N/A’)>>> dd[’key1’] = ’abc’>>> dd[’key1’] # key1存在’abc’>>> dd[’key2’] # key2不存在,返回默認(rèn)值’N/A’

注意默認(rèn)值是調(diào)用函數(shù)返回的,而函數(shù)在創(chuàng)建defaultdict對(duì)象時(shí)傳入。

除了在Key不存在時(shí)返回默認(rèn)值,defaultdict的其他行為跟dict是完全一樣的。

OrderedDict

使用dict時(shí),Key是無(wú)序的。在對(duì)dict做迭代時(shí),我們無(wú)法確定Key的順序。

如果要保持Key的順序,可以用OrderedDict:

>>> from collections import OrderedDict>>> d = dict([(’a’, 1), (’b’, 2), (’c’, 3)])>>> d # dict的Key是無(wú)序的{’a’: 1, ’c’: 3, ’b’: 2}>>> od = OrderedDict([(’a’, 1), (’b’, 2), (’c’, 3)])>>> od # OrderedDict的Key是有序的OrderedDict([(’a’, 1), (’b’, 2), (’c’, 3)])

注意,OrderedDict的Key會(huì)按照插入的順序排列,不是Key本身排序:

>>> od = OrderedDict()>>> od[’z’] = 1>>> od[’y’] = 2>>> od[’x’] = 3>>> od.keys() # 按照插入的Key的順序返回[’z’, ’y’, ’x’]

OrderedDict可以實(shí)現(xiàn)一個(gè)FIFO(先進(jìn)先出)的dict,當(dāng)容量超出限制時(shí),先刪除最早添加的Key:

from collections import OrderedDictclass LastUpdatedOrderedDict(OrderedDict): def __init__(self, capacity): super(LastUpdatedOrderedDict, self).__init__() self._capacity = capacity def __setitem__(self, key, value): containsKey = 1 if key in self else 0 if len(self) - containsKey >= self._capacity: last = self.popitem(last=False) print ’remove:’, last if containsKey: del self[key] print ’set:’, (key, value) else: print ’add:’, (key, value) OrderedDict.__setitem__(self, key, value)

Counter

Counter是一個(gè)簡(jiǎn)單的計(jì)數(shù)器,例如,統(tǒng)計(jì)字符出現(xiàn)的個(gè)數(shù):

>>> from collections import Counter>>> c = Counter()>>> for ch in ’programming’:... c[ch] = c[ch] + 1...>>> cCounter({’g’: 2, ’m’: 2, ’r’: 2, ’a’: 1, ’i’: 1, ’o’: 1, ’n’: 1, ’p’: 1})

Counter實(shí)際上也是dict的一個(gè)子類,上面的結(jié)果可以看出,字符’g’、’m’、’r’各出現(xiàn)了兩次,其他字符各出現(xiàn)了一次。

小結(jié)

collections模塊提供了一些有用的集合類,可以根據(jù)需要選用。

知識(shí)點(diǎn)補(bǔ)充:

在內(nèi)置數(shù)據(jù)類型(dict、list、set、tuple)的基礎(chǔ)上,collections模塊還提供了幾個(gè)額外的數(shù)據(jù)類型:Counter、deque、defaultdict、namedtuple和OrderedDict等。

1.namedtuple: 生成可以使用名字來(lái)訪問(wèn)元素內(nèi)容的tuple

2.deque: 雙端隊(duì)列,可以快速的從另外一側(cè)追加和推出對(duì)象

3.Counter: 計(jì)數(shù)器,主要用來(lái)計(jì)數(shù)

4.OrderedDict: 有序字典

5.defaultdict: 帶有默認(rèn)值的字典

以上就是Python中內(nèi)建模塊collections如何使用的詳細(xì)內(nèi)容,更多關(guān)于詳解Python中的內(nèi)建模塊collections的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Python 編程
相關(guān)文章:
主站蜘蛛池模板: 合肥宠物店装修_合肥宠物美容院装修_合肥宠物医院设计装修公司-安徽盛世和居装饰 | 申江储气罐厂家,储气罐批发价格,储气罐规格-上海申江压力容器有限公司(厂) | 气动球阀_衬氟蝶阀_调节阀_电动截止阀_上海沃托阀门有限公司 | 锥形螺带干燥机(新型耙式干燥机)百科-常州丰能干燥工程 | 跨境物流_美国卡派_中大件运输_尾程派送_海外仓一件代发 - 广州环至美供应链平台 | 精益专家 - 设备管理软件|HSE管理系统|设备管理系统|EHS安全管理系统 | TYPE-C厂家|TYPE-C接口|TYPE-C防水母座|TYPE-C贴片-深圳步步精 | 农业仪器网 - 中国自动化农业仪器信息交流平台 | 冷却塔改造厂家_不锈钢冷却塔_玻璃钢冷却塔改造维修-广东特菱节能空调设备有限公司 | 手术示教系统-数字化手术室系统-林之硕医疗云智能视频平台 | 胀套-锁紧盘-风电锁紧盘-蛇形联轴器「厂家」-瑞安市宝德隆机械配件有限公司 | 变频器维修公司_plc维修_伺服驱动器维修_工控机维修 - 夫唯科技 变位机,焊接变位机,焊接变位器,小型变位机,小型焊接变位机-济南上弘机电设备有限公司 | 深圳善跑体育产业集团有限公司_塑胶跑道_人造草坪_运动木地板 | 时代北利离心机,实验室离心机,医用离心机,低速离心机DT5-2,美国SKC采样泵-上海京工实业有限公司 工业电炉,台车式电炉_厂家-淄博申华工业电炉有限公司 | 螺旋绞龙叶片,螺旋输送机厂家,山东螺旋输送机-淄博长江机械制造有限公司 | 政府回应:200块在义乌小巷能买到爱情吗?——揭秘打工族省钱约会的生存智慧 | 拉伸膜,PE缠绕膜,打包带,封箱胶带,包装膜厂家-东莞宏展包装 | 网站建设,北京网站建设,北京网站建设公司,网站系统开发,北京网站制作公司,响应式网站,做网站公司,海淀做网站,朝阳做网站,昌平做网站,建站公司 | 生鲜配送系统-蔬菜食材配送管理系统-连锁餐饮订货配送软件-挪挪生鲜供应链管理软件 | 磁力抛光研磨机_超声波清洗机厂家_去毛刺设备-中锐达数控 | H型钢切割机,相贯线切割机,数控钻床,数控平面钻,钢结构设备,槽钢切割机,角钢切割机,翻转机,拼焊矫一体机 | 二手注塑机回收_旧注塑机回收_二手注塑机买卖 - 大鑫二手注塑机 二手光谱仪维修-德国OBLF光谱仪|进口斯派克光谱仪-热电ARL光谱仪-意大利GNR光谱仪-永晖检测 | 乐考网-银行从业_基金从业资格考试_初级/中级会计报名时间_中级经济师 | 3d打印服务,3d打印汽车,三维扫描,硅胶复模,手板,快速模具,深圳市精速三维打印科技有限公司 | 搬运设备、起重设备、吊装设备—『龙海起重成套设备』 | 翻斗式矿车|固定式矿车|曲轨侧卸式矿车|梭式矿车|矿车配件-山东卓力矿车生产厂家 | 齿轮减速马达一体式_蜗轮蜗杆减速机配电机-德国BOSERL齿轮减速电动机生产厂家 | 中国玩具展_玩具展|幼教用品展|幼教展|幼教装备展 | 森旺-A级防火板_石英纤维板_不燃抗菌板装饰板_医疗板 | 温州中研白癜风专科_温州治疗白癜风_温州治疗白癜风医院哪家好_温州哪里治疗白癜风 | 致胜管家软件服务【在线免费体验】 | 密集架|电动密集架|移动密集架|黑龙江档案密集架-大量现货厂家销售 | 环氧铁红防锈漆_环氧漆_无溶剂环氧涂料_环氧防腐漆-华川涂料 | 网站优化公司_北京网站优化_抖音短视频代运营_抖音关键词seo优化排名-通则达网络 | 岩棉切条机厂家_玻璃棉裁条机_水泥基保温板设备-廊坊鹏恒机械 | 帽子厂家_帽子工厂_帽子定做_义乌帽厂_帽厂_制帽厂 | 工程管道/塑料管材/pvc排水管/ppr给水管/pe双壁波纹管等品牌管材批发厂家-河南洁尔康建材 | 新密高铝耐火砖,轻质保温砖价格,浇注料厂家直销-郑州荣盛窑炉耐火材料有限公司 | 北京自然绿环境科技发展有限公司专业生产【洗车机_加油站洗车机-全自动洗车机】 | 杭州翻译公司_驾照翻译_专业人工翻译-杭州以琳翻译有限公司官网 组织研磨机-高通量组织研磨仪-实验室多样品组织研磨机-东方天净 | 恒温恒湿箱(药品/保健品/食品/半导体/细菌)-兰贝石(北京)科技有限公司 |