欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python的collections模塊真的很好用

 更新時間:2021年03月01日 11:08:18   作者:運(yùn)維派  
collections是實(shí)現(xiàn)了特定目標(biāo)的容器,以提供Python標(biāo)準(zhǔn)內(nèi)建容器 dict , list , set , 和 tuple 的替代選擇,本文詳細(xì)總結(jié)collections的相關(guān)知識,感興趣的朋友跟隨看看吧

collections是實(shí)現(xiàn)了特定目標(biāo)的容器,以提供Python標(biāo)準(zhǔn)內(nèi)建容器 dict , list , set , 和 tuple 的替代選擇。為了讓大家更好的認(rèn)識,本文詳細(xì)總結(jié)collections的相關(guān)知識,一起來學(xué)習(xí)吧!

collections模塊:實(shí)現(xiàn)了特定目標(biāo)的容器,以提供Python標(biāo)準(zhǔn)內(nèi)建容器 dict、list、set、tuple 的替代選擇。

Counter:字典的子類,提供了可哈希對象的計(jì)數(shù)功能。

defaultdict:字典的子類,提供了一個工廠函數(shù),為字典查詢提供了默認(rèn)值。

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

namedtuple:創(chuàng)建命名元組子類的工廠函數(shù)。

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

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

Counter

Counter是一個dict子類,主要是用來對你訪問的對象的頻率進(jìn)行計(jì)數(shù)。

>>> import collections
>>> # 統(tǒng)計(jì)字符出現(xiàn)的次數(shù)
... collections.Counter('hello world')
Counter({'l': 3, 'o': 2, 'h': 1, 'e': 1, ' ': 1, 'w': 1, 'r': 1, 'd': 1})
>>> # 統(tǒng)計(jì)單詞個數(shù)
... collections.Counter('hello world hello lucy'.split())
Counter({'hello': 2, 'world': 1, 'lucy': 1})

常用方法:

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

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

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

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

>>> c = collections.Counter('hello world hello lucy'.split())
>>> c
Counter({'hello': 2, 'world': 1, 'lucy': 1})
>>> # 獲取指定對象的訪問次數(shù),也可以使用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 是內(nèi)置 dict 類的子類。

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

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

例子

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

>>> e = collections.defaultdict(str)
>>> e
defaultdict(<class 'str'>, {})
>>> e['hello']
''
>>> e
defaultdict(<class 'str'>, {'hello': ''})
>>> # 普通字典調(diào)用不存在的鍵時,報(bào)錯
... 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['手機(jī)'].add('華為')
>>> types['手機(jī)'].add('小米')
>>> types['顯示器'].add('AOC')
>>> types
defaultdict(<class 'set'>, {'手機(jī)': {'華為', '小米'}, '顯示器': {'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')])

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

```python
>>> o['k1'] = 666
>>> o
OrderedDict([('k1', 666), ('k3', 'v3'), ('k2', 'v2')])
>>> dict(o)
{'k1': 666, 'k3': 'v3', 'k2': 'v2'}

## namedtuple

三種定義命名元組的方法:第一個參數(shù)是命名元組的構(gòu)造器(如下的: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')

實(shí)例化命名元組

```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 # 直接通過 實(shí)例名.屬性 來調(diào)用
'lucy'
>>> lucy.age
23

deque

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

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

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

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

支持的方法:

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

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

clear():清除所有元素,長度變?yōu)?。

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

count(x):計(jì)算隊(duì)列中個數(shù)等于x的元素。

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

extendleft(iterable):在隊(duì)列左側(cè)添加iterable中的元素,注:在左側(cè)添加時,iterable參數(shù)的順序?qū)催^來添加。

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

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

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

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

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

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

maxlen:隊(duì)列的最大長度,沒有限定則為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

問題背景是我們有多個字典或者映射,想把它們合并成為一個單獨(dú)的映射,有人說可以用update進(jìn)行合并,這樣做的問題就是新建了一個數(shù)據(jù)結(jié)構(gòu)以致于當(dāng)我們對原來的字典進(jìn)行更改的時候不會同步。如果想建立一個同步的查詢方法,可以使用 ChainMap。

可以用來合并兩個或者更多個字典,當(dāng)查詢的時候,從前往后依次查詢。簡單使用:

```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>

有一個注意點(diǎn)就是當(dāng)對ChainMap進(jìn)行修改的時候總是只會對第一個字典進(jìn)行修改,如果第一個字典不存在該鍵,會添加。

<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 實(shí)際上是把放入的字典存儲在一個隊(duì)列中,當(dāng)進(jìn)行字典的增加刪除等操作只會在第一個字典上進(jìn)行,當(dāng)進(jìn)行查找的時候會依次查找,new_child() 方法實(shí)質(zhì)上是在列表的第一個元素前放入一個字典,默認(rèn)是{},而 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({})

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

相關(guān)文章

  • Python tkinter 樹形列表控件(Treeview)的使用方法

    Python tkinter 樹形列表控件(Treeview)的使用方法

    這篇文章主要介紹了Python tkinter 樹形列表控件(Treeview)的使用方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • Windows下為Python安裝Matplotlib模塊

    Windows下為Python安裝Matplotlib模塊

    這篇文章主要介紹了如何在Windows下為Python安裝Matplotlib模塊的方法,非常的詳細(xì),而且附上了官方的下載地址,小伙伴們操作起來應(yīng)該毫無壓力了。
    2015-11-11
  • python使用正則表達(dá)式分析網(wǎng)頁中的圖片并進(jìn)行替換的方法

    python使用正則表達(dá)式分析網(wǎng)頁中的圖片并進(jìn)行替換的方法

    這篇文章主要介紹了python使用正則表達(dá)式分析網(wǎng)頁中的圖片并進(jìn)行替換的方法,涉及Python使用正則表達(dá)式的技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-03-03
  • Python實(shí)現(xiàn)輕松找出文本文件中的高頻單詞

    Python實(shí)現(xiàn)輕松找出文本文件中的高頻單詞

    當(dāng)想要深入了解一段文本,最常見的需求之一就是找到其中出現(xiàn)頻率最高的單詞,下面小編就來為大家詳細(xì)介紹一下如何使用Python實(shí)現(xiàn)輕松找出文本文件中的高頻單詞,需要的可以參考下
    2023-11-11
  • Python中BeautifulSoup通過查找Id獲取元素信息

    Python中BeautifulSoup通過查找Id獲取元素信息

    這篇文章主要介紹了Python中BeautifulSoup通過查找Id獲取元素信息,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • Pycharm設(shè)置utf-8自動顯示方法

    Pycharm設(shè)置utf-8自動顯示方法

    今天小編就為大家分享一篇Pycharm設(shè)置utf-8自動顯示方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-01-01
  • TensorFlow神經(jīng)網(wǎng)絡(luò)優(yōu)化策略學(xué)習(xí)

    TensorFlow神經(jīng)網(wǎng)絡(luò)優(yōu)化策略學(xué)習(xí)

    這篇文章主要介紹了TensorFlow神經(jīng)網(wǎng)絡(luò)優(yōu)化策略
    2018-03-03
  • Python中的__init__作用是什么

    Python中的__init__作用是什么

    在本篇文章里小編給大家分享的是關(guān)于Python中的__init__作用以及相關(guān)用法內(nèi)容,需要的朋友們可以學(xué)習(xí)下。
    2020-06-06
  • Python捕獲全局的KeyboardInterrupt異常的方法實(shí)現(xiàn)

    Python捕獲全局的KeyboardInterrupt異常的方法實(shí)現(xiàn)

    KeyboardInterrupt異常是Python中的一個標(biāo)準(zhǔn)異常,它通常發(fā)生在用戶通過鍵盤中斷了一個正在運(yùn)行的程序,本文主要介紹了Python捕獲全局的KeyboardInterrupt異常的方法實(shí)現(xiàn),感興趣的可以了解一下
    2024-08-08
  • Flask??請求鉤子的實(shí)現(xiàn)

    Flask??請求鉤子的實(shí)現(xiàn)

    這篇文章主要給大家分享了Flask請求鉤子的實(shí)現(xiàn),在客戶端和服務(wù)器交互的過程中,有些準(zhǔn)備工作或掃尾工作需要處理,比如:在請求開始時,建立數(shù)據(jù)庫連接;在請求開始時,根據(jù)需求進(jìn)行權(quán)限校驗(yàn);在請求結(jié)束時,指定數(shù)據(jù)的交互格式;下面來看看文章詳細(xì)介紹內(nèi)容吧
    2021-11-11

最新評論