学无止境

少年辛苦终身事,莫向光阴惰寸功。——唐·杜荀鹤《题弟侄书堂》


Python Collections Duque函数演示

  • duque函数有一个maxlen参数,当append的时候,如果超过,那么最前面的就会被挤出队列
from collections import duque
def search(lines, pattern, lens=5):
    previous_lines = deque(maxlen=lens)
    for li in lines:
        if pattern in li:
            yield li, previous_lines
        previous_lines.append(li)

if name == main:
    with open(r./xx.txt) as f:
        for line, prevlines in search(f, python, 5):
            for pline in prevlines:
                print(pline, end=’’)
            print(line, end=’’)
        print(** * 20)