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

