Python cookbook(數(shù)據(jù)結構與算法)保存最后N個元素的方法
本文實例講述了Python保存最后N個元素的方法。分享給大家供大家參考,具體如下:
問題:希望在迭代或是其他形式的處理過程中對最后幾項記錄做一個有限的歷史記錄統(tǒng)計
解決方案:選擇collections.deque。
如下的代碼對一系列文本行做簡單的文本匹配操作,當發(fā)現(xiàn)有匹配時就輸出當前的匹配行以及最后檢查過的N行文本:
from collections import deque
def search(lines, pattern, history=5):
previous_lines = deque(maxlen=history)
for line in lines:
if pattern in line:
yield line, previous_lines
previous_lines.append(line)
# Example use on a file
if __name__ == '__main__':
with open('somefile.txt') as f:
for line, prevlines in search(f, 'python', 5):
for pline in prevlines:
print(pline, end='')
print(line, end='')
print('-'*20)

正如上面的代碼一樣,當編寫搜索某項記錄的代碼時,通常會用到含有yield關鍵字的生成器函數(shù),將處理搜索過程的代碼與使用搜索結果的代碼解耦開來。具體生成器可參考本站迭代器和生成器相關內(nèi)容。
deque(maxlen=N)創(chuàng)建一個固定長度的隊列,當加入新元素而隊列已滿時會自動移除最老的那條記錄:
>>> from collections import deque >>> q=deque(maxlen=3) >>> q.append(1) >>> q.append(2) >>> q.append(3) >>> q deque([1, 2, 3], maxlen=3) >>> q.append(4) >>> q deque([2, 3, 4], maxlen=3) >>> q.append(5) >>> q deque([3, 4, 5], maxlen=3) >>>
盡管可以在列表上手動完成這樣的操作(append、del),但隊列的這種解決方案要優(yōu)雅得多,運行速度也快得多。
如果不指定隊列長度,則得到一個無界限的隊列,可在兩端執(zhí)行添加和彈出操作:
>>> q=deque() >>> q deque([]) >>> q.append(1) >>> q.append(2) >>> q.append(3) >>> q deque([1, 2, 3]) >>> q.appendleft(4) >>> q deque([4, 1, 2, 3]) >>> q.pop() 3 >>> q deque([4, 1, 2]) >>> q.popleft() 4 >>> q deque([1, 2]) >>>
更多關于Python相關內(nèi)容感興趣的讀者可查看本站專題:《Python數(shù)據(jù)結構與算法教程》、《Python加密解密算法與技巧總結》、《Python編碼操作技巧總結》、《Python函數(shù)使用技巧總結》、《Python字符串操作技巧匯總》及《Python入門與進階經(jīng)典教程》
希望本文所述對大家Python程序設計有所幫助。
- Python實現(xiàn)的數(shù)據(jù)結構與算法之隊列詳解
- Python數(shù)據(jù)結構與算法之圖的最短路徑(Dijkstra算法)完整實例
- Python數(shù)據(jù)結構與算法之列表(鏈表,linked list)簡單實現(xiàn)
- Python數(shù)據(jù)結構與算法之圖結構(Graph)實例分析
- 詳解常用查找數(shù)據(jù)結構及算法(Python實現(xiàn))
- Python實現(xiàn)的數(shù)據(jù)結構與算法之快速排序詳解
- Python實現(xiàn)的數(shù)據(jù)結構與算法之鏈表詳解
- Python實現(xiàn)的數(shù)據(jù)結構與算法之雙端隊列詳解
- Python cookbook(數(shù)據(jù)結構與算法)實現(xiàn)查找兩個字典相同點的方法
- 詳解python數(shù)據(jù)結構和算法
相關文章
Python實現(xiàn)二叉排序樹與平衡二叉樹的示例代碼
樹表查詢即借助具有特殊性質的樹數(shù)據(jù)結構進行關鍵字查找,本文所涉及到的特殊結構性質的樹包括:二叉排序樹、平衡二叉樹。文中詳細介紹了二者的實現(xiàn)代碼,需要的可以參考一下2022-04-04
使用Python的Twisted框架編寫簡單的網(wǎng)絡客戶端
這篇文章主要介紹了使用Python的Twisted框架編寫簡單的網(wǎng)絡客戶端,翻譯自Twisted文檔,包括一個簡單的IRC客戶端的實現(xiàn),需要的朋友可以參考下2015-04-04
python selenium 執(zhí)行完畢關閉chromedriver進程示例
今天小編就為大家分享一篇python selenium 執(zhí)行完畢關閉chromedriver進程示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11

