詳解Python 中的容器 collections
寫在之前
我們都知道 Python 中內(nèi)置了許多標準的數(shù)據(jù)結(jié)構(gòu),比如列表,元組,字典等。與此同時標準庫還提供了一些額外的數(shù)據(jù)結(jié)構(gòu),我們可以基于它們創(chuàng)建所需的新數(shù)據(jù)結(jié)構(gòu)。
Python 附帶了一個「容器」模塊 collections,它包含了很多的容器數(shù)據(jù)類型,今天我們來討論其中幾個常用的容器數(shù)據(jù)類型,掌握了這幾個可以減少我們重復(fù)造輪子所帶來的煩擾。
namedtuple
相信你已經(jīng)熟悉了元組。一個元組相當于一個不可變的列表,你可以存儲一個數(shù)據(jù)的序列。這里要說的 namedtuple(命名元組)和元組非常像,它們都不能修改自己的數(shù)據(jù)。說完了像,那么它們有哪些地方不像呢?
作為元組,為了獲取其中的數(shù)據(jù),我們需要使用整數(shù)作為索引:
>>> people = ('Rocky', 'python')
>>> print(people[0])
Rocky
而 namedtuple 把元組變成了一個針對簡單任務(wù)的容器,我們不必使用整數(shù)索引來訪問 namedtuple 的數(shù)據(jù),反而可以像用字典一樣訪問 namedtuple。
>>> from collections import namedtuple
>>> people = namedtuple('people', 'name age like')
>>> Rocky = people(name = 'rocky', age = 23, like = 'python')
>>> print(Rocky)
people(name='rocky', age=23, like='python')
>>> print(Rocky.name)
rocky
一個 namedtuple 有兩個必須的參數(shù):元組名稱和字段名稱。在上面的代碼中,我們的元組名稱是 people,字段名稱是 name,age,like。nametuple 讓元組變的更加易讀,很容易理解代碼是做什么的,同樣我們也不用使用整數(shù)索引來訪問一個命名元組(上面代碼我們用 name 訪問了 namedtuple 中的數(shù)據(jù)),這讓我們的代碼更加容易維護。
但是你一定要記住的是,雖然它的用法很爽,但它還是一個元組!所以屬性值在 namedtuple 中是不可變的。
我們在上面說過可以像用字典一樣訪問 namedtuple,那么當然也可以把它轉(zhuǎn)為字典,具體操作如下所示:
>>> from collections import namedtuple
>>> people = namedtuple('people', 'name age like')
>>> Rocky = people(name = 'rocky', age = 23, like = 'python')
>>> print(Rocky._asdict())
OrderedDict([('name', 'rocky'), ('age', 23), ('like', 'python')])
defaultdict
我之前在使用字典的時候相當隨意,只是隨便 dict 一下就好了,然而這樣使用存在一個問題:當使用的 key 不存在的時候會報 KeyError,而 defaultdict 就比較厲害了,我們完全不需要檢查 key 是否存在,所以我們能像下面這樣做的隨心所欲:
from collections import defaultdict
languages = (
('rocky', 'python'),
('snow', 'c'),
('leey', 'java'),
('rocky', 'c++'),
('leey', 'c#')
)
favourite = defaultdict(list)
for name, language in languages:
favourite[name].append(language)
print(favourite)
輸出如下所示:
defaultdict(<type 'list'>, {'leey': ['java', 'c#'], 'rocky': ['python', 'c++'], 'snow': ['c']})
然后我們再回到“鍵不存在,會觸發(fā) KeyError 異?!边@個問題上來,我們先來看 dict 觸發(fā) KeyError 的例子:
my_dict = {}
my_dict['name']['like'] = 'python'
輸出如下:
KeyError: 'name'
defaultdict 則用了一個非常巧妙的方式繞過了這個問題,請看下面的操作:
import collections language = lambda : collections.defaultdict(language) my_dict = language() my_dict['name']['like'] = 'python'
運行一下顯示正常,我們可以用 json.dumps 打印出 my_dict 的內(nèi)容:
import json print(json.dumps(my_dict))
運行結(jié)果如下:
{"name": {"like": "python"}}
Counter
Counter 是一個計數(shù)器,它可以幫助我們針對某項數(shù)據(jù)進行計數(shù),比如可以用它來統(tǒng)計每個人擅長的編程語言:
from collections import Counter
languages = (
('rocky', 'python'),
('snow', 'c'),
('leey', 'java'),
('rocky', 'c++'),
('leey', 'c#')
)
cnt = Counter(name for name, language in languages)
print(cnt)
運行結(jié)果如下所示:
Counter({'leey': 2, 'rocky': 2, 'snow': 1})
當然我們也可以用它來統(tǒng)計一個文件,比如:
from collections import Counter
with open('test.txt', 'rb') as f:
line_cnt = Counter(f)
print(line_cnt)
deque
deque 提供了一個雙端隊列,我們可以在首尾兩端添加或者刪除元素
想要使用 deque,首先我們要從 collections 中導(dǎo)入 deque 模塊,然后創(chuàng)建一個 deque 對象,它的用法就像我們前面學過的 list 一樣,并且提供了類似的方法,具體如下所示:
from collections import deque deq = deque() deq.append(1) deq.append(2) deq.append(3) print(deq) print(len(deq)) print(deq[0]) print(deq[-1])
輸出結(jié)果如下:
deque([1, 2, 3])
3
1
3
我們可以從兩端取出數(shù)據(jù):
from collections import deque
deq = deque(range(5))
print('len(deq) == {}'.format(len(deq)))
deq.popleft()
deq.pop()
print(deq)
輸出的結(jié)果如下所示:
len(deq) == 5
deq == deque([1, 2, 3])
我們也可以對這個列表的大小進行限制,當超出我們的限制的時候,數(shù)據(jù)會從另一端被 pop 出去,具體我們來看下面的操作:
from collections import deque deq = deque(maxlen=3) deq.append(1) deq.append(2) deq.append(3) print(deq) deq.append(4) print (deq)
輸出的結(jié)果如下:
deque([1, 2, 3], maxlen=3)
deque([2, 3, 4], maxlen=3)
當超出 maxlen 的值時,最左邊的數(shù)據(jù)將從隊列中刪除。
當然我們還可以從任意一端擴展這個雙端隊列中的數(shù)據(jù):
from collections import deque deq = deque([1,2,3]) deq.extendleft([0]) deq.extend([4,5,6]) print(deq)
輸出的結(jié)果如下所示:
deque([0, 1, 2, 3, 4, 5, 6])
以上就是詳解Python 中的容器 collections的詳細內(nèi)容,更多關(guān)于python collections的資料請關(guān)注腳本之家其它相關(guān)文章!
- Python中Collections模塊的Counter容器類使用教程
- python函數(shù)enumerate,operator和Counter使用技巧實例小結(jié)
- 淺談python中統(tǒng)計計數(shù)的幾種方法和Counter詳解
- Python中使用Counter進行字典創(chuàng)建以及key數(shù)量統(tǒng)計的方法
- python3+PyQt5實現(xiàn)自定義窗口部件Counters
- 簡單掌握Python的Collections模塊中counter結(jié)構(gòu)的用法
- python Matplotlib數(shù)據(jù)可視化(2):詳解三大容器對象與常用設(shè)置
- Docker構(gòu)建python Flask+ nginx+uwsgi容器
- Python容器類型公共方法總結(jié)
- Python魔法方法 容器部方法詳解
- Python統(tǒng)計可散列的對象之容器Counter詳解
相關(guān)文章
Python?FastAPI?Sanic?Tornado?與Golang?Gin性能實戰(zhàn)對比
本文將深入比較Python的FastAPI、Sanic、Tornado以及Golang的Gin框架的各種特性、性能表現(xiàn)以及適用場景,通過詳實的性能測試和實際示例代碼,將探討它們在構(gòu)建現(xiàn)代高性能應(yīng)用中的優(yōu)劣勢,以便開發(fā)者根據(jù)需求做出明智的選擇2024-01-01
Ubuntu下使用python讀取doc和docx文檔的內(nèi)容方法
今天小編就為大家分享一篇Ubuntu下使用python讀取doc和docx文檔的內(nèi)容方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-05-05
windows系統(tǒng)上通過whl文件安裝triton模塊的簡單步驟
這篇文章主要介紹了在Windows系統(tǒng)中通過.whl文件安裝Triton的步驟,包括確認系統(tǒng)環(huán)境、下載合適的.whl文件、使用pip安裝、驗證安裝、使用Triton以及解決潛在問題,需要的朋友可以參考下2025-01-01
升級Python版本后anaconda navigator啟動失敗解決方案(最新推薦)
anaconda navigator啟動失敗,尤其是重裝不解決問題的,大概率是庫沖突,解決方法也很簡單,只需要刪掉引起沖突的庫,感興趣的朋友跟隨小編一起看看吧2023-11-11
python爬蟲系列Selenium定向爬取虎撲籃球圖片詳解
這篇文章主要介紹了python爬蟲系列Selenium定向爬取虎撲籃球圖片詳解,具有一定參考價值,喜歡的朋友可以了解下。2017-11-11
python內(nèi)置函數(shù)map/filter/reduce詳解
在Python中,map(), filter(), 和 reduce() 是內(nèi)置的高級函數(shù)(實際是class),用于處理可迭代對象(如列表、元組等)的元素,這篇文章主要介紹了python內(nèi)置函數(shù)map/filter/reduce的相關(guān)知識,需要的朋友可以參考下2024-05-05
Python調(diào)用Windows API函數(shù)編寫錄音機和音樂播放器功能
這篇文章主要介紹了Python調(diào)用Windows API函數(shù)編寫錄音機和音樂播放器功能,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2020-01-01
python 如何將office文件轉(zhuǎn)換為PDF
這篇文章主要介紹了python 如何將office文件轉(zhuǎn)換為PDF,幫助大家更好的理解和使用python,感興趣的朋友可以了解下2020-09-09

