Python cookbook(数据结构与算法)保存最后N个元素的方法


Posted in Python onFebruary 13, 2018

本文实例讲述了Python保存最后N个元素的方法。分享给大家供大家参考,具体如下:

问题:希望在迭代或是其他形式的处理过程中对最后几项记录做一个有限的历史记录统计

解决方案:选择collections.deque。

如下的代码对一系列文本行做简单的文本匹配操作,当发现有匹配时就输出当前的匹配行以及最后检查过的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)

Python cookbook(数据结构与算法)保存最后N个元素的方法

正如上面的代码一样,当编写搜索某项记录的代码时,通常会用到含有yield关键字的生成器函数,将处理搜索过程的代码与使用搜索结果的代码解耦开来。具体生成器可参考本站迭代器和生成器相关内容。

deque(maxlen=N)创建一个固定长度的队列,当加入新元素而队列已满时会自动移除最老的那条记录:

>>> 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),但队列的这种解决方案要优雅得多,运行速度也快得多。

如果不指定队列长度,则得到一个无界限的队列,可在两端执行添加和弹出操作:

>>> 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程序设计有所帮助。

Python 相关文章推荐
Python爬取APP下载链接的实现方法
Sep 30 Python
Flask框架的学习指南之开发环境搭建
Nov 20 Python
python实现分页效果
Oct 25 Python
python如何统计序列中元素
Jul 31 Python
浅析python打包工具distutils、setuptools
Apr 20 Python
Python数据可视化:箱线图多种库画法
Nov 06 Python
tensorflow-gpu安装的常见问题及解决方案
Jan 20 Python
python利用xlsxwriter模块 操作 Excel
Oct 14 Python
Python eval函数介绍及用法
Nov 09 Python
解决pytorch 数据类型报错的问题
Mar 03 Python
OpenCV-Python直方图均衡化实现图像去雾
Jun 07 Python
Python使用DFA算法过滤内容敏感词
Apr 22 Python
Python cookbook(数据结构与算法)从任意长度的可迭代对象中分解元素操作示例
Feb 13 #Python
Python cookbook(数据结构与算法)将序列分解为单独变量的方法
Feb 13 #Python
Python内置模块ConfigParser实现配置读写功能的方法
Feb 12 #Python
Python内置模块hashlib、hmac与uuid用法分析
Feb 12 #Python
20个常用Python运维库和模块
Feb 12 #Python
使用python实现BLAST
Feb 12 #Python
Python内置模块logging用法实例分析
Feb 12 #Python
You might like
thinkphp中连接oracle时封装方法无法用的解决办法
2013/06/17 PHP
thinkphp实现分页显示功能
2016/12/03 PHP
使用PHP访问RabbitMQ消息队列的方法示例
2018/06/06 PHP
解决laravel 表单提交-POST 异常的问题
2019/10/15 PHP
javascript import css实例代码
2008/07/18 Javascript
Extjs TriggerField在弹出窗口显示不出问题的解决方法
2010/01/08 Javascript
js中查找最近的共有祖先元素的实现代码
2010/12/30 Javascript
js动态加载以及确定加载完成的代码
2011/07/31 Javascript
Google Maps API地图应用示例分享
2014/10/23 Javascript
对JavaScript客户端应用编程的一些建议
2015/06/24 Javascript
jquery实现的Accordion折叠面板效果代码
2015/09/02 Javascript
Jquery easyui 实现动态树
2015/11/17 Javascript
JavaScript中三种异步上传文件方式
2016/03/06 Javascript
神奇!js+CSS+DIV实现文字颜色渐变效果
2016/03/16 Javascript
JS简单实现表格排序功能示例
2016/12/20 Javascript
jquery将标签元素的高设为屏幕的百分比
2017/04/19 jQuery
vue实现登陆登出的实现示例
2017/09/15 Javascript
Element-UI Table组件上添加列拖拽效果实现方法
2018/04/14 Javascript
vuejs2.0运用原生js实现简单拖拽元素功能
2020/08/21 Javascript
JavaScript碎片—函数闭包(模拟面向对象)
2019/03/13 Javascript
axios实现简单文件上传功能
2019/09/25 Javascript
Python实现正弦信号的时域波形和频谱图示例【基于matplotlib】
2018/05/04 Python
python连接mongodb密码认证实例
2018/10/16 Python
对python多线程中互斥锁Threading.Lock的简单应用详解
2019/01/11 Python
pytorch+lstm实现的pos示例
2020/01/14 Python
Python自动化操作实现图例绘制
2020/07/09 Python
PyTorch安装与基本使用详解
2020/08/31 Python
基于CSS3的animation属性实现微信拍一拍动画效果
2020/06/22 HTML / CSS
CSS3 实现弹跳的小球动画
2020/10/26 HTML / CSS
Hanro官网:奢华男士和女士内衣、睡衣和家居服
2018/10/25 全球购物
Bed Bath & Beyond加拿大官网:购买床上用品、浴巾、厨房电器等
2019/10/04 全球购物
如何查询Oracle数据库中已经创建的索引
2013/10/11 面试题
审计工作个人的自我评价
2013/12/25 职场文书
求职信格式范文
2015/03/19 职场文书
2015年后勤工作总结范文
2015/04/08 职场文书
国际最新研究在陨石中发现DNA主要成分 或由陨石带来地球
2022/04/29 数码科技