国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Python > 正文

Python cookbook(數據結構與算法)保存最后N個元素的方法

2020-01-04 15:50:53
字體:
來源:轉載
供稿:網友

本文實例講述了Python保存最后N個元素的方法。分享給大家供大家參考,具體如下:

問題:希望在迭代或是其他形式的處理過程中對最后幾項記錄做一個有限的歷史記錄統計

解決方案:選擇collections.deque。

如下的代碼對一系列文本行做簡單的文本匹配操作,當發現有匹配時就輸出當前的匹配行以及最后檢查過的N行文本:

from collections import dequedef 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 fileif __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)

Python,cookbook,數據結構與算法,最后N個元素

正如上面的代碼一樣,當編寫搜索某項記錄的代碼時,通常會用到含有yield關鍵字的生成器函數,將處理搜索過程的代碼與使用搜索結果的代碼解耦開來。具體生成器可參考本站迭代器和生成器相關內容。

deque(maxlen=N)創建一個固定長度的隊列,當加入新元素而隊列已滿時會自動移除最老的那條記錄:

>>> from collections import deque>>> q=deque(maxlen=3)>>> q.append(1)>>> q.append(2)>>> q.append(3)>>> qdeque([1, 2, 3], maxlen=3)>>> q.append(4)>>> qdeque([2, 3, 4], maxlen=3)>>> q.append(5)>>> qdeque([3, 4, 5], maxlen=3)>>>

盡管可以在列表上手動完成這樣的操作(append、del),但隊列的這種解決方案要優雅得多,運行速度也快得多。

如果不指定隊列長度,則得到一個無界限的隊列,可在兩端執行添加和彈出操作:

>>> q=deque()>>> qdeque([])>>> q.append(1)>>> q.append(2)>>> q.append(3)>>> qdeque([1, 2, 3])>>> q.appendleft(4)>>> qdeque([4, 1, 2, 3])>>> q.pop()3>>> qdeque([4, 1, 2])>>> q.popleft()4>>> qdeque([1, 2])>>>

希望本文所述對大家Python程序設計有所幫助。


注:相關教程知識閱讀請移步到python教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 田阳县| 临安市| 贵港市| 察雅县| 海安县| 旌德县| 罗定市| 治多县| 东光县| 英吉沙县| 大悟县| 明溪县| 罗田县| 屏东县| 布拖县| 德庆县| 昌图县| 马关县| 南昌县| 景洪市| 石狮市| 水城县| 稷山县| 余姚市| 扎兰屯市| 商河县| 周宁县| 搜索| 临澧县| 石台县| 普陀区| 高尔夫| 黄冈市| 关岭| 元谋县| 庆城县| 石楼县| 潜山县| 南陵县| 建湖县| 石楼县|