校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > Python的collections模塊真的很好用

Python的collections模塊真的很好用

熱門標簽:qt百度地圖標注 遼寧智能外呼系統需要多少錢 地圖地圖標注有嘆號 正安縣地圖標注app 電銷機器人系統廠家鄭州 螳螂科技外呼系統怎么用 400電話申請資格 阿里電話機器人對話 舉辦過冬奧會的城市地圖標注

collections是實現了特定目標的容器,以提供Python標準內建容器 dict , list , set , 和 tuple 的替代選擇。為了讓大家更好的認識,本文詳細總結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())
>>> c
Counter({'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())
>>> c1
Counter({'hello': 1, 'world': 1})
>>> c2
Counter({'hello': 1, 'lucy': 1})
>>> # 追加對象,+或者c1.update(c2)
... c1+c2
Counter({'hello': 2, 'world': 1, 'lucy': 1})
>>> # 減少對象,-或者c1.subtract(c2)
... c1-c2
Counter({'world': 1})
>>> # 清除
... c.clear()
>>> c
Counter()

defaultdict

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

class collections.defaultdict([default_factory[, ...]])

>>> d = collections.defaultdict()
>>> d
defaultdict(None, {})
>>> e = collections.defaultdict(str)
>>> e
defaultdict(class 'str'>, {})

例子

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

>>> e = collections.defaultdict(str)
>>> e
defaultdict(class 'str'>, {})
>>> e['hello']
''
>>> e
defaultdict(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
>>> fruit
defaultdict(class 'int'>, {'apple': 2})
>>> fruit['banana'] # 沒有對象時,返回0
0
>>> fruit
defaultdict(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)
...
>>> d
defaultdict(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}
>>> nums
defaultdict(, {1: {'one': 1}})
>>> nums[2]
{}
>>> nums
defaultdict(, {1: {'one': 1}, 2: {}})

使用 set 作為 default_factory

```python
>>> types = collections.defaultdict(set)
>>> types['手機'].add('華為')
>>> types['手機'].add('小米')
>>> types['顯示器'].add('AOC')
>>> types
defaultdict(class 'set'>, {'手機': {'華為', '小米'}, '顯示器': {'AOC'}})

## OrderedDict

Python字典中的鍵的順序是任意的,它們不受添加的順序的控制。

collections.OrderedDict 類提供了保留他們添加順序的字典對象。

```python
>>> o = collections.OrderedDict()
>>> o['k1'] = 'v1'
>>> o['k3'] = 'v3'
>>> o['k2'] = 'v2'
>>> o
OrderedDict([('k1', 'v1'), ('k3', 'v3'), ('k2', 'v2')])

如果在已經存在的 key 上添加新的值,將會保留原來的 key 的位置,然后覆蓋 value 值。

```python
>>> o['k1'] = 666
>>> o
OrderedDict([('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)
>>> lucy
Person1(name='lucy', age=23, height=180)
>>> jack = P2('jack',20,190)
>>> jack
Person2(name='jack', age=20, height=190)
>>> lucy.name # 直接通過 實例名.屬性 來調用
'lucy'
>>> lucy.age
23

deque

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)
>>> d
deque([], 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')
>>> d
deque(['h', 'g', 'f', 'p', 'y', 't', 'h', 'o', 'n', 'e'], maxlen=10)
>>> d.appendleft('i')
>>> d
deque(['i', 'h', 'g', 'f', 'p', 'y', 't', 'h', 'o', 'n'], maxlen=10)
>>> d.append('m')
>>> d
deque(['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)
>>> combined1
ChainMap({'apple': 1, 'banana': 2}, {'orange': 2, 'apple': 3, 'pike': 1})
>>> combined2
ChainMap({'orange': 2, 'apple': 3, 'pike': 1}, {'apple': 1, 'banana': 2})
>>> for k,v in combined1.items():
...   print(k,v)
...
orange 2
apple 1
pike 1
banana 2
>>> for k,v in combined2.items():
...   print(k,v)
...
apple 3
banana 2
orange 2
pike 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)
>>> c
ChainMap({'apple': 1, 'banana': 2}, {'orange': 2, 'apple': 3, 'pike': 1})
>>> c['apple']
1
>>> c['apple'] = 2
>>> c
ChainMap({'apple': 2, 'banana': 2}, {'orange': 2, 'apple': 3, 'pike': 1})
>>> c['pike']
1
>>> c['pike'] = 3
>>> c
ChainMap({'apple': 2, 'banana': 2, 'pike': 3}, {'orange': 2, 'apple': 3, 'pike': 1})

從原理上面講,ChainMap 實際上是把放入的字典存儲在一個隊列中,當進行字典的增加刪除等操作只會在第一個字典上進行,當進行查找的時候會依次查找,new_child() 方法實質上是在列表的第一個元素前放入一個字典,默認是{},而 parents 是去掉了列表開頭的元素。

```python
>>> a = collections.ChainMap()
>>> a['x'] = 1
>>> a
ChainMap({'x': 1})
>>> b = a.new_child()
>>> b
ChainMap({}, {'x': 1})
>>> b['x'] = 2
>>> b
ChainMap({'x': 2}, {'x': 1})
>>> b['y'] = 3
>>> b
ChainMap({'x': 2, 'y': 3}, {'x': 1})
>>> a
ChainMap({'x': 1})
>>> c = a.new_child()
>>> c
ChainMap({}, {'x': 1})
>>> c['x'] = 1
>>> c['y'] = 1
>>> c
ChainMap({'x': 1, 'y': 1}, {'x': 1})
>>> d = c.parents
>>> d
ChainMap({'x': 1})
>>> d is a
False
>>> d == a
True

>>> a = {'x':1,'z':3}
>>> b = {'y':2,'z':4}
>>> c = collections.ChainMap(a,b)
>>> c
ChainMap({'x': 1, 'z': 3}, {'y': 2, 'z': 4})
>>> c.maps
[{'x': 1, 'z': 3}, {'y': 2, 'z': 4}]
>>> c.parents
ChainMap({'y': 2, 'z': 4})
>>> c.parents.maps
[{'y': 2, 'z': 4}]
>>> c.parents.parents
ChainMap({})
>>> c.parents.parents.parents
ChainMap({})

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

您可能感興趣的文章:
  • python 中的collections.OrderedDict() 用法
  • Python collections模塊的使用技巧
  • Java基礎詳解之集合框架工具Collections
  • 如何在C#中使用只讀的 Collections
  • Java中Collections.emptyList()的注意事項
  • Java Collections類操作集合詳解
  • python collections模塊的使用
  • Python collections模塊的使用方法
  • Java Collections.shuffle()方法案例詳解

標簽:興安盟 隨州 合肥 淘寶好評回訪 濟源 昭通 信陽 阜新

巨人網絡通訊聲明:本文標題《Python的collections模塊真的很好用》,本文關鍵詞  Python,的,collections,模塊,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《Python的collections模塊真的很好用》相關的同類信息!
  • 本頁收集關于Python的collections模塊真的很好用的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    26uuu国产电影一区二区| 久久国产夜色精品鲁鲁99| 蜜臀99久久精品久久久久久软件| 国产尤物一区二区在线| 欧美日韩精品系列| 国产精品久久久久久久久免费樱桃| 亚洲狠狠爱一区二区三区| 国产成人亚洲综合a∨猫咪| 欧美日韩国产色站一区二区三区| 国产精品你懂的在线| 国产精品正在播放| 精品处破学生在线二十三| 青青草精品视频| 精品欧美黑人一区二区三区| 国产一区二区在线观看视频| 91精品久久久久久蜜臀| 亚洲国产成人av好男人在线观看| 一本高清dvd不卡在线观看| 婷婷开心激情综合| 欧美一区二区女人| 日韩国产一二三区| 国产欧美一区在线| 欧美日韩国产免费一区二区 | 蜜桃av一区二区在线观看| 欧美日韩不卡在线| 午夜电影网一区| 精品久久久影院| 91在线观看下载| 午夜视频久久久久久| 国产精品美女久久久久久久| 91视频国产观看| 日本网站在线观看一区二区三区| 久久综合狠狠综合久久综合88| 成人性视频网站| 亚洲午夜精品久久久久久久久| 欧美精品电影在线播放| 国产一区二区三区免费看| 日韩电影在线观看一区| **欧美大码日韩| 欧美日产国产精品| a4yy欧美一区二区三区| 奇米888四色在线精品| 天堂蜜桃91精品| 亚洲同性gay激情无套| 欧美mv日韩mv国产网站app| 91老司机福利 在线| 99久久99久久精品免费看蜜桃| 国产成人免费网站| 精品一区二区三区视频在线观看 | 亚洲欧美另类小说视频| 日韩欧美一级特黄在线播放| 国产乱人伦偷精品视频不卡| 亚洲女同ⅹxx女同tv| 精品久久久久久综合日本欧美| 成人小视频免费在线观看| 日韩电影免费在线看| 亚洲成人一区在线| 久久久精品tv| 精品久久久久久久一区二区蜜臀| 欧美三级资源在线| 国产91高潮流白浆在线麻豆| 精品一区二区免费视频| 亚洲成人综合在线| 国产日产精品一区| 欧美日韩精品福利| 欧美人妖巨大在线| 91精品国产欧美一区二区18| 日韩精品一区在线| 精品久久人人做人人爰| 欧美乱妇一区二区三区不卡视频| av日韩在线网站| 99久久国产综合精品色伊| 欧美性xxxxx极品少妇| 欧美日韩国产首页在线观看| 欧美色国产精品| 欧美日韩国产欧美日美国产精品| 色呦呦国产精品| 欧美精选在线播放| 欧美日韩国产一级| 精品国产乱码久久久久久久| 日本一区二区免费在线| 一区二区三区美女| 丝袜美腿亚洲一区二区图片| 韩日精品视频一区| 欧美亚洲国产怡红院影院| 欧美一区二区免费视频| 国产精品高潮呻吟久久| 蜜臀91精品一区二区三区| 99精品国产视频| 精品国精品国产| 天天综合网天天综合色| 成人免费视频一区| 欧美三级一区二区| 亚洲免费在线观看视频| 国产黄色91视频| 久久老女人爱爱| 久久69国产一区二区蜜臀| 69堂成人精品免费视频| 亚洲va韩国va欧美va| 成人免费视频caoporn| 欧美成人vr18sexvr| 亚洲va韩国va欧美va| av成人老司机| 亚洲日本护士毛茸茸| 91网站视频在线观看| 亚洲欧洲另类国产综合| 高清不卡在线观看av| 日韩一级视频免费观看在线| 日韩vs国产vs欧美| 精品少妇一区二区| 免费的国产精品| 亚洲精品在线观看网站| 国产美女精品一区二区三区| 日韩美女天天操| 国精产品一区一区三区mba视频 | 久久亚洲影视婷婷| 粉嫩高潮美女一区二区三区| 国产精品入口麻豆九色| 国产在线精品一区二区三区不卡| 欧美不卡一区二区三区| 国产福利电影一区二区三区| 国产精品国产自产拍高清av王其| 国产成人综合在线| 亚洲图片欧美激情| 69堂成人精品免费视频| 久久电影网站中文字幕 | 国产麻豆一精品一av一免费| 国产婷婷一区二区| 色婷婷av一区二区三区gif| 天堂资源在线中文精品| 国产欧美一区二区精品婷婷| 成人a区在线观看| 亚洲大片在线观看| 国产亚洲精久久久久久| 欧美亚洲图片小说| 国产高清亚洲一区| 日韩av中文在线观看| 欧美精品一区视频| 欧美三级视频在线| 99久久伊人精品| 日韩成人午夜精品| 亚洲视频免费在线观看| 精品国产123| 欧美一级欧美三级在线观看| 成人h精品动漫一区二区三区| 蜜臀国产一区二区三区在线播放| 欧美国产日韩一二三区| 欧美一区二区日韩| 欧美色图12p| 成人午夜精品一区二区三区| 美女视频黄频大全不卡视频在线播放| 亚洲一级在线观看| 26uuu亚洲综合色| 亚洲精品在线网站| 久久免费午夜影院| 国产精品美女久久久久久2018| 精品国产a毛片| 久久久久久久久岛国免费| 久久久久久久久久久久久久久99| 色悠悠久久综合| 成人动漫一区二区三区| 99re成人精品视频| 一本大道av伊人久久综合| 久久激五月天综合精品| 精品亚洲aⅴ乱码一区二区三区| 蜜臀久久99精品久久久画质超高清| 国产精品视频线看| 亚洲欧美区自拍先锋| 亚洲第一电影网| 国产一区二区三区| 国产福利一区二区三区在线视频| 成人激情黄色小说| 欧美色图激情小说| 日韩精品中文字幕在线一区| 中文字幕av一区二区三区高 | 日韩欧美国产麻豆| 久久亚洲捆绑美女| 亚洲一区二区三区四区在线 | 国产欧美日韩久久| 午夜精品在线视频一区| 欧美三级三级三级爽爽爽| 日本一区二区三区久久久久久久久不 | 亚洲欧美偷拍另类a∨色屁股| 韩国一区二区三区| 欧美人体做爰大胆视频| 亚洲黄色片在线观看| 国产高清精品在线| 国产欧美日韩综合| 国产高清精品在线| 久久久三级国产网站| 精品一区二区三区不卡| 欧美电影免费观看高清完整版在线观看| 午夜一区二区三区视频| 欧美性做爰猛烈叫床潮| 亚洲综合图片区| 91精品婷婷国产综合久久 | 国产精品毛片久久久久久| 大白屁股一区二区视频| 国产精品久久久久7777按摩| av在线不卡观看免费观看|