python?中collections的?deque使用詳解
1 概要
deque 是一個(gè)雙端隊(duì)列, 如果要經(jīng)常從兩端append 的數(shù)據(jù), 選擇這個(gè)數(shù)據(jù)結(jié)構(gòu)就比較好了, 如果要實(shí)現(xiàn)隨機(jī)訪問,不建議用這個(gè),請用列表.
deque 優(yōu)勢就是可以從兩邊append ,appendleft 數(shù)據(jù). 這一點(diǎn)list 是沒有的.
#-*- coding: UTF-8 -*-
import time
from collections import deque
# 可以指定 隊(duì)列的長度
mydeque=deque(maxlen=10)
mydeque.maxlen
Out[43]: 10
# 默認(rèn)從右邊加入
mydeque.append(10)
mydeque.append(12)
mydeque
Out[7]: deque([10, 12])
# time.sleep(4)
# 也可以從左邊加入
mydeque.appendleft('a')
mydeque.appendleft('b')
mydeque.appendleft('c')
mydeque.appendleft('d')
mydeque.appendleft('e')
mydeque
Out[11]: deque(['e', 'd', 'c', 'b', 'a', 10, 12])
mylist= range(5,8)
# 也可以加入一個(gè)列表,默認(rèn)從右邊加入
# mydeque.extend(mylist)
mydeque.extendleft(mylist)
mydeque
Out[14]: deque([7, 6, 5, 'e', 'd', 'c', 'b', 'a', 10, 12])
# 出隊(duì)列,返回出隊(duì)列的元素
# 可以從左邊也可以從右邊 出隊(duì)列
mydeque.pop()
mydeque.popleft()
# 查看 隊(duì)列里面元素個(gè)數(shù)
print len(mydeque)
# 統(tǒng)計(jì)元素的個(gè)數(shù)
#統(tǒng)計(jì)a 有幾個(gè)
print mydeque.count('a')
# 在某個(gè)位置insert 一個(gè)元素
# insert(i, x)
# Insert x into the deque at position i.
d1
Out[31]: deque([10, 12, 13, 14])
d1.insert(2,'frank')
d1
Out[33]: deque([10, 12, 'frank', 13, 14])
#翻轉(zhuǎn)操作
# deque.reverse()
mydeque
Out[52]: deque([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])
mydeque.reverse()
mydeque
Out[54]: deque([9, 8, 7, 6, 5, 4, 3, 2, 1, 0])
# remove 移除某個(gè)元素
mydeque
Out[23]: deque(['e', 'd', 'c', 'b', 'a', 10, 12])
mydeque.remove(10)
mydeque
Out[25]: deque(['e', 'd', 'c', 'b', 'a', 12])
# 清空隊(duì)列元素 clear
mydeque
Out[46]: deque([0, 1, 2, 3, 4, 5, 6, 7, 8, 9])
mydeque.clear
Out[47]: <function deque.clear>
mydeque.clear()
mydeque
Out[49]: deque([])
# copy 淺拷貝
# Create a shallow copy of the deque.
l1 = [6, 5, 8, 3, 9, 0, 2, 7, 4, 1]
d3 = deque(l1)
d3
Out[64]: deque([6, 5, 8, 3, 9, 0, 2, 7, 4, 1])
d4 = d3.copy()
d4
Out[66]: deque([6, 5, 8, 3, 9, 0, 2, 7, 4, 1])2 重要方法說明
rotate 方法:
移動(dòng)到最后一個(gè),占用第一個(gè)位置,循環(huán)移動(dòng), value 是步長,rotate(value) 對隊(duì)列實(shí)行旋轉(zhuǎn)操作(每個(gè)元素依次向后移動(dòng)value步,最后一個(gè)移動(dòng)到第一個(gè)算一步)
from collections import deque d = deque() d.extend(['a', 'b', 'c', 'd', 'e']) d.rotate(2) # 指定次數(shù),默認(rèn)1次 print(d) # deque(['d', 'e', 'a', 'b', 'c'])
maxlen 要說明一下, 如果指定了 maxlen
- 如果構(gòu)建deque 的時(shí)候,指定了maxlen, 則可以通過 d.maxlen 來獲得dueue的最大長度.
- 如果插入的數(shù)據(jù)大于 maxlen 則會(huì)自動(dòng)刪除舊的元素.
- 刪除 什么元素,取決于, 從哪邊添加數(shù)據(jù).
來看一下例子:
d = deque(list(range(5)),maxlen=5)
d
Out[21]: deque([0, 1, 2, 3, 4])
d.maxlen
Out[26]: 5
# 從左邊添加元素, # 元素4 被擠出 隊(duì)列
d.appendleft('frank')
d
Out[23]: deque(['frank', 0, 1, 2, 3])
# 從右邊添加元素, 元素 'frank' 被擠出隊(duì)列.
d
Out[23]: deque(['frank', 0, 1, 2, 3])
d.append('xiaoming')
d
Out[25]: deque([0, 1, 2, 3, 'xiaoming'])3 總結(jié)
deque 是為了高效實(shí)現(xiàn)插入和刪除操作的雙向列表
總結(jié) :
- deque 的方法 雙端隊(duì)列 ,進(jìn)入隊(duì)列,默認(rèn)從右邊進(jìn)入,
- 出隊(duì)列 默認(rèn)從右邊出隊(duì)列,
- 移除隊(duì)列元素
- insert()
- appendleft()
- append()
- extend(...)
- extendleft(...)
隊(duì)列長度 len(deque)
- pop()
- popleft()
count(value) ? # 統(tǒng)計(jì)某個(gè)值出現(xiàn)的個(gè)數(shù) remove(...) reverse() ?? #輪詢向前走n,最后一個(gè)元素往前移動(dòng),第一個(gè)元素依次后移? rotate(n=1)
清空隊(duì)列: dequeue.clear()
到此這篇關(guān)于python 中collections的 deque使用詳解的文章就介紹到這了,更多相關(guān)Python deque內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
基于使用paramiko執(zhí)行遠(yuǎn)程linux主機(jī)命令(詳解)
下面小編就為大家?guī)硪黄谑褂胮aramiko執(zhí)行遠(yuǎn)程linux主機(jī)命令(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-10-10
Python Flask利用SocketIO庫實(shí)現(xiàn)圖表的繪制
這篇文章主要為大家詳細(xì)介紹了Python Flask框架如何利用SocketIO庫實(shí)現(xiàn)圖表的繪制,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起了解一下2022-12-12
Python requests發(fā)送post請求的一些疑點(diǎn)
在Python爬蟲中,使用requests發(fā)送請求,訪問指定網(wǎng)站,是常見的做法,這篇文章主要介紹了Python requests發(fā)送post請求的一些疑點(diǎn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05
MATLAB如何利用散點(diǎn)進(jìn)行函數(shù)曲線擬合
這篇文章主要介紹了MATLAB如何利用散點(diǎn)進(jìn)行函數(shù)曲線擬合問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11
pycharm日志總是彈出“無法運(yùn)行Git,未安裝Git”的問題
這篇文章主要介紹了pycharm日志總是彈出“無法運(yùn)行Git,未安裝Git”的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06
解讀卷積神經(jīng)網(wǎng)絡(luò)的人臉識(shí)別
這篇文章主要介紹了解讀卷積神經(jīng)網(wǎng)絡(luò)的人臉識(shí)別問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11

