日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Python的collections模塊真的很好用

瀏覽:213日期:2022-06-26 17:05:20

collections是實現了特定目標的容器,以提供Python標準內建容器 dict , list , set , 和 tuple 的替代選擇。為了讓大家更好的認識,本文詳細總結collections的相關知識,一起來學習吧!

Python的collections模塊真的很好用

collections模塊:實現了特定目標的容器,以提供Python標準內建容器 dict、list、set、tuple 的替代選擇。

Counter:字典的子類,提供了可哈希對象的計數功能。

defaultdict:字典的子類,提供了一個工廠函數,為字典查詢提供了默認值。

OrderedDict:字典的子類,保留了他們被添加的順序。

namedtuple:創建命名元組子類的工廠函數。

deque:類似列表容器,實現了在兩端快速添加(append)和彈出(pop)。

ChainMap:類似字典的容器類,將多個映射集合到一個視圖里面。

Counter

Counter是一個dict子類,主要是用來對你訪問的對象的頻率進行計數。

>>> import collections>>> # 統計字符出現的次數... collections.Counter(’hello world’)Counter({’l’: 3, ’o’: 2, ’h’: 1, ’e’: 1, ’ ’: 1, ’w’: 1, ’r’: 1, ’d’: 1})>>> # 統計單詞個數... collections.Counter(’hello world hello lucy’.split())Counter({’hello’: 2, ’world’: 1, ’lucy’: 1})

常用方法:

elements():返回一個迭代器,每個元素重復計算的個數,如果一個元素的計數小于1,就會被忽略。

most_common([n]):返回一個列表,提供n個訪問頻率最高的元素和計數

subtract([iterable-or-mapping]):從迭代對象中減去元素,輸入輸出可以是0或者負數

update([iterable-or-mapping]):從迭代對象計數元素或者從另一個 映射對象 (或計數器) 添加。

>>> c = collections.Counter(’hello world hello lucy’.split())>>> cCounter({’hello’: 2, ’world’: 1, ’lucy’: 1})>>> # 獲取指定對象的訪問次數,也可以使用get方法... c[’hello’]2>>> # 查看元素... list(c.elements())[’hello’, ’hello’, ’world’, ’lucy’]>>> c1 = collections.Counter(’hello world’.split())>>> c2 = collections.Counter(’hello lucy’.split())>>> c1Counter({’hello’: 1, ’world’: 1})>>> c2Counter({’hello’: 1, ’lucy’: 1})>>> # 追加對象,+或者c1.update(c2)... c1+c2Counter({’hello’: 2, ’world’: 1, ’lucy’: 1})>>> # 減少對象,-或者c1.subtract(c2)... c1-c2Counter({’world’: 1})>>> # 清除... c.clear()>>> cCounter()

defaultdict

返回一個新的類似字典的對象。defaultdict 是內置 dict 類的子類。

class collections.defaultdict([default_factory[, ...]])>>> d = collections.defaultdict()>>> ddefaultdict(None, {})>>> e = collections.defaultdict(str)>>> edefaultdict(<class ’str’>, {})

例子

defaultdict的一個典型用法是使用其中一種內置類型(如str、int、list或dict等)作為默認工廠,這些內置類型在沒有參數調用時返回空類型。

>>> e = collections.defaultdict(str)>>> edefaultdict(<class ’str’>, {})>>> e[’hello’]’’>>> edefaultdict(<class ’str’>, {’hello’: ’’})>>> # 普通字典調用不存在的鍵時,報錯... e1 = {}>>> e1[’hello’]Traceback (most recent call last): File '<stdin>', line 1, in <module>KeyError: ’hello’使用 int 作為 default_factory>>> fruit = collections.defaultdict(int)>>> fruit[’apple’] = 2>>> fruitdefaultdict(<class ’int’>, {’apple’: 2})>>> fruit[’banana’] # 沒有對象時,返回00>>> fruitdefaultdict(<class ’int’>, {’apple’: 2, ’banana’: 0})

使用 list 作為 default_factory

>>> s = [(’yellow’, 1), (’blue’, 2), (’yellow’, 3), (’blue’, 4), (’red’, 1)]>>> d = collections.defaultdict(list)>>> for k,v in s:... d[k].append(v)...>>> ddefaultdict(<class ’list’>, {’yellow’: [1, 3], ’blue’: [2, 4], ’red’: [1]})>>> d.items()dict_items([(’yellow’, [1, 3]), (’blue’, [2, 4]), (’red’, [1])])>>> sorted(d.items())[(’blue’, [2, 4]), (’red’, [1]), (’yellow’, [1, 3])]使用 dict 作為 default_factory```python>>> nums = collections.defaultdict(dict)>>> nums[1] = {’one’:1}>>> numsdefaultdict(, {1: {’one’: 1}})>>> nums[2]{}>>> numsdefaultdict(, {1: {’one’: 1}, 2: {}})使用 set 作為 default_factory```python>>> types = collections.defaultdict(set)>>> types[’手機’].add(’華為’)>>> types[’手機’].add(’小米’)>>> types[’顯示器’].add(’AOC’)>>> typesdefaultdict(<class ’set’>, {’手機’: {’華為’, ’小米’}, ’顯示器’: {’AOC’}})## OrderedDictPython字典中的鍵的順序是任意的,它們不受添加的順序的控制。collections.OrderedDict 類提供了保留他們添加順序的字典對象。```python>>> o = collections.OrderedDict()>>> o[’k1’] = ’v1’>>> o[’k3’] = ’v3’>>> o[’k2’] = ’v2’>>> oOrderedDict([(’k1’, ’v1’), (’k3’, ’v3’), (’k2’, ’v2’)])如果在已經存在的 key 上添加新的值,將會保留原來的 key 的位置,然后覆蓋 value 值。```python>>> o[’k1’] = 666>>> oOrderedDict([(’k1’, 666), (’k3’, ’v3’), (’k2’, ’v2’)])>>> dict(o){’k1’: 666, ’k3’: ’v3’, ’k2’: ’v2’}## namedtuple三種定義命名元組的方法:第一個參數是命名元組的構造器(如下的:Person1,Person2,Person3)```python>>> P1 = collections.namedtuple(’Person1’,[’name’,’age’,’height’])>>> P2 = collections.namedtuple(’Person2’,’name,age,height’)>>> P3 = collections.namedtuple(’Person3’,’name age height’)實例化命名元組```python>>> lucy = P1(’lucy’,23,180)>>> lucyPerson1(name=’lucy’, age=23, height=180)>>> jack = P2(’jack’,20,190)>>> jackPerson2(name=’jack’, age=20, height=190)>>> lucy.name # 直接通過 實例名.屬性 來調用’lucy’>>> lucy.age23deque

collections.deque 返回一個新的雙向隊列對象,從左到右初始化(用方法 append()),從 iterable(迭代對象)數據創建。如果 iterable 沒有指定,新隊列為空。

collections.deque 隊列支持線程安全,對于從兩端添加(append)或者彈出(pop),復雜度O(1)。

雖然 list 對象也支持類似操作,但是這里優化了定長操作(pop(0)、insert(0,v))的開銷。

如果 maxlen 沒有指定或者是 None ,deque 可以增長到任意長度。否則,deque 就限定到指定最大長度。一旦限定長度的 deque 滿了,當新項加入時,同樣數量的項就從另一端彈出。

支持的方法:

append(x):添加x到右端。

appendleft(x):添加x到左端。

clear():清除所有元素,長度變為0。

copy():創建一份淺拷貝。

count(x):計算隊列中個數等于x的元素。

extend(iterable):在隊列右側添加iterable中的元素。

extendleft(iterable):在隊列左側添加iterable中的元素,注:在左側添加時,iterable參數的順序將會反過來添加。

index(x[,start[,stop]]):返回第 x 個元素(從 start 開始計算,在 stop 之前)。返回第一個匹配,如果沒找到的話,拋出 ValueError 。

insert(i,x):在位置 i 插入 x 。注:如果插入會導致一個限長deque超出長度 maxlen 的話,就拋出一個 IndexError 。

pop():移除最右側的元素。

popleft():移除最左側的元素。

remove(value):移去找到的第一個 value。沒有拋出ValueError。

reverse():將deque逆序排列。返回 None 。

maxlen:隊列的最大長度,沒有限定則為None。

>>> d = collections.deque(maxlen=10)>>> ddeque([], maxlen=10)>>> d.extend(’python’)>>> [i.upper() for i in d][’P’, ’Y’, ’T’, ’H’, ’O’, ’N’]>>> d.append(’e’)>>> d.appendleft(’f’)>>> d.appendleft(’g’)>>> d.appendleft(’h’)>>> ddeque([’h’, ’g’, ’f’, ’p’, ’y’, ’t’, ’h’, ’o’, ’n’, ’e’], maxlen=10)>>> d.appendleft(’i’)>>> ddeque([’i’, ’h’, ’g’, ’f’, ’p’, ’y’, ’t’, ’h’, ’o’, ’n’], maxlen=10)>>> d.append(’m’)>>> ddeque([’h’, ’g’, ’f’, ’p’, ’y’, ’t’, ’h’, ’o’, ’n’, ’m’], maxlen=10)## ChainMap問題背景是我們有多個字典或者映射,想把它們合并成為一個單獨的映射,有人說可以用update進行合并,這樣做的問題就是新建了一個數據結構以致于當我們對原來的字典進行更改的時候不會同步。如果想建立一個同步的查詢方法,可以使用 ChainMap。可以用來合并兩個或者更多個字典,當查詢的時候,從前往后依次查詢。簡單使用:```python>>> d1 = {’apple’:1,’banana’:2}>>> d2 = {’orange’:2,’apple’:3,’pike’:1}>>> combined1 = collections.ChainMap(d1,d2)>>> combined2 = collections.ChainMap(d2,d1)>>> combined1ChainMap({’apple’: 1, ’banana’: 2}, {’orange’: 2, ’apple’: 3, ’pike’: 1})>>> combined2ChainMap({’orange’: 2, ’apple’: 3, ’pike’: 1}, {’apple’: 1, ’banana’: 2})>>> for k,v in combined1.items():... print(k,v)...orange 2apple 1pike 1banana 2>>> for k,v in combined2.items():... print(k,v)...apple 3banana 2orange 2pike 1</code></pre>有一個注意點就是當對ChainMap進行修改的時候總是只會對第一個字典進行修改,如果第一個字典不存在該鍵,會添加。<pre><code class='language-python line-numbers'>>>> d1 = {’apple’:1,’banana’:2}>>> d2 = {’orange’:2,’apple’:3,’pike’:1}>>> c = collections.ChainMap(d1,d2)>>> cChainMap({’apple’: 1, ’banana’: 2}, {’orange’: 2, ’apple’: 3, ’pike’: 1})>>> c[’apple’]1>>> c[’apple’] = 2>>> cChainMap({’apple’: 2, ’banana’: 2}, {’orange’: 2, ’apple’: 3, ’pike’: 1})>>> c[’pike’]1>>> c[’pike’] = 3>>> cChainMap({’apple’: 2, ’banana’: 2, ’pike’: 3}, {’orange’: 2, ’apple’: 3, ’pike’: 1})從原理上面講,ChainMap 實際上是把放入的字典存儲在一個隊列中,當進行字典的增加刪除等操作只會在第一個字典上進行,當進行查找的時候會依次查找,new_child() 方法實質上是在列表的第一個元素前放入一個字典,默認是{},而 parents 是去掉了列表開頭的元素。```python>>> a = collections.ChainMap()>>> a[’x’] = 1>>> aChainMap({’x’: 1})>>> b = a.new_child()>>> bChainMap({}, {’x’: 1})>>> b[’x’] = 2>>> bChainMap({’x’: 2}, {’x’: 1})>>> b[’y’] = 3>>> bChainMap({’x’: 2, ’y’: 3}, {’x’: 1})>>> aChainMap({’x’: 1})>>> c = a.new_child()>>> cChainMap({}, {’x’: 1})>>> c[’x’] = 1>>> c[’y’] = 1>>> cChainMap({’x’: 1, ’y’: 1}, {’x’: 1})>>> d = c.parents>>> dChainMap({’x’: 1})>>> d is aFalse>>> d == aTrue>>> a = {’x’:1,’z’:3}>>> b = {’y’:2,’z’:4}>>> c = collections.ChainMap(a,b)>>> cChainMap({’x’: 1, ’z’: 3}, {’y’: 2, ’z’: 4})>>> c.maps[{’x’: 1, ’z’: 3}, {’y’: 2, ’z’: 4}]>>> c.parentsChainMap({’y’: 2, ’z’: 4})>>> c.parents.maps[{’y’: 2, ’z’: 4}]>>> c.parents.parentsChainMap({})>>> c.parents.parents.parentsChainMap({})

到此這篇關于Python的collections模塊真的很好用的文章就介紹到這了,更多相關Python的collections模塊內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美影院三区| 黄色在线观看www| 伊人精品一区| 狠狠色综合网| 中文字幕日韩亚洲| 日韩av一区二区在线影视| 国产精品亚洲欧美日韩一区在线| 久久精品毛片| 激情婷婷亚洲| 日韩精品亚洲一区二区三区免费| 国产欧美日韩一级| 成人国产综合| 国产视频欧美| 国产精品一区二区美女视频免费看| 精品三区视频| 亚洲黄色影院| 日本不卡高清视频| 国产伊人久久| 亚洲一区免费| 国产精品日本一区二区不卡视频| 肉色欧美久久久久久久免费看| 国产精品美女| 欧美国产免费| 偷拍欧美精品| 国产免费久久| 欧美亚洲国产精品久久| 日本亚州欧洲精品不卡| 久草免费在线视频| 亚洲日本欧美| 天堂av在线| 免费久久精品视频| 麻豆精品视频在线观看| 午夜国产精品视频| 国产激情一区| 日韩中文字幕区一区有砖一区 | 亚洲精品影视| jizzjizz中国精品麻豆| 一本综合精品| 国产精品原创| 婷婷精品久久久久久久久久不卡| 久久久久久亚洲精品美女| 日韩午夜高潮| 麻豆成人91精品二区三区| 亚洲一区二区三区免费在线观看| 国产精品qvod| 中文字幕日韩亚洲| 91tv亚洲精品香蕉国产一区| 欧美三区不卡| 视频一区二区欧美| 激情国产在线| 欧美精品福利| 久久亚洲国产精品一区二区| 中文字幕在线免费观看视频| 日韩区欧美区| 成人精品天堂一区二区三区| 国产精品男女| 午夜性色一区二区三区免费视频| 99久精品视频在线观看视频| 另类小说一区二区三区| 亚洲精品影视| 国产亚洲综合精品| 成人亚洲欧美| 国产精品啊啊啊| 亚洲精品麻豆| 亚洲一区二区三区高清| 久久精品国内一区二区三区水蜜桃| 国产精品亚洲综合在线观看| 一级欧美视频| 黄色欧美日韩| 婷婷激情一区| 国产在线不卡一区二区三区| 国产美女亚洲精品7777| 喷白浆一区二区| 日韩视频二区| 激情综合自拍| 久久五月天小说| 成人日韩精品| 国产91在线播放精品| 久久爱www.| 国产亚洲电影| 91综合久久爱com| 日韩中文字幕| 日本伊人午夜精品| 亚洲欧美日韩国产综合精品二区 | av资源新版天堂在线| 国产精品xxx在线观看| 日韩高清在线一区| 免费在线观看视频一区| 免费成人在线视频观看| 久久国产88| 国产精品呻吟| 99成人在线视频| 91一区二区三区四区| 美女在线视频一区| 69堂精品视频在线播放| 亚洲精品进入| 日韩激情网站| 青青草91久久久久久久久| 一级成人国产| 亚洲毛片网站| 欧美一区二区三区久久精品| 欧美日韩一区二区三区在线电影| 日本欧美一区二区| 国产精品网在线观看| 国产精品中文字幕亚洲欧美| 国产精品白浆| 波多野结衣久久精品| 日韩毛片在线| 亚洲免费中文| 免费国产亚洲视频| 久久精品97| 成人精品高清在线视频| 欧美日韩中文一区二区| 国产精品日本| 91麻豆精品激情在线观看最新| 国产精品免费99久久久| а√天堂8资源在线| 欧美亚洲国产激情| 日韩精品一级中文字幕精品视频免费观看| 亚洲精品乱码久久久久久蜜桃麻豆 | 日韩免费久久| 亚洲国产专区| 亚洲欧洲国产精品一区| 国产精品久久久久久妇女| 天堂av在线| 美女精品在线观看| 国产日韩高清一区二区三区在线| 电影91久久久| 欧美在线资源| 欧美亚洲色图校园春色| 亚洲国产欧美日本视频| 巨乳诱惑日韩免费av| 欧美a在线观看| 亚洲男女av一区二区| 国产欧美一区二区三区精品观看 | 亚州欧美在线| 久久亚洲人体| 香蕉精品999视频一区二区| 国产精品永久| 亚洲精品电影| 久久影视三级福利片| 欧美在线资源| 国产精品美女午夜爽爽| 亚洲女同中文字幕| 国产剧情在线观看一区| 极品日韩av| 欧美国产另类| 久色成人在线| 精品视频一区二区三区在线观看 | 黄毛片在线观看| 亚洲伊人精品酒店| 日韩福利一区| 国产亚洲欧美日韩精品一区二区三区| 欧美一区二区三区高清视频| 国产精品一线天粉嫩av| 性欧美长视频| 麻豆mv在线观看| 日韩精品免费一区二区夜夜嗨| 成人精品亚洲| 国产极品一区| 免费在线观看视频一区| 91一区二区三区四区| 日韩精品午夜视频| 黄色成人精品网站| a日韩av网址| 国产精久久久| 亚洲久久视频| 99热精品在线| 欧美sss在线视频| 嫩呦国产一区二区三区av| 中文字幕一区二区精品区| 久久精品成人| 久久女人天堂| 婷婷精品在线| 亚洲少妇在线| 国产中文一区| 亚洲成av在线| 国产一区二区三区久久久久久久久| 婷婷精品在线| 日韩在线一二三区| 欧美网站在线| 久久在线免费| 日韩中文在线电影| 久久精品国产99国产精品| 巨乳诱惑日韩免费av| 美女网站一区| 91亚洲人成网污www| 国产精品午夜一区二区三区| 亚洲精一区二区三区| 亚洲免费激情| 亚洲欧洲日本mm| 亚洲天堂成人| 欧美日一区二区| 日本久久成人网| 女生影院久久| 欧美二三四区| 久久九九国产| 日韩精品影视| 欧洲av不卡| 婷婷综合六月|