#!/usr/bin/env python
import time
def tail(filepath,encoding='utf-8'):
with open(filepath,encoding=encoding) as f:
f.seek(0,2) #最后依次数字0代表从头开始,1代表当前位置,2代表末尾开始,前边的数字代表偏移量。
while True:
line=f.readline()
if line:
yield line
else:
time.sleep(1)
def grep(lines,pattern):
for line in lines:
# print(line)
if pattern in line:
yield line #这里把第一次监测完的内容再次用生成器函数筛选,然后用生成器依次执行实现输出结果。
g=tail('a.txt.py')
g1=grep(g,'error')
g2=grep(g1,'404')
for i in g2:
print(i) #目前我的理解是生成器就是为了把函数的一些步骤的执行结果赋予返回值,当然前提是这些返回值后续可以用得到。
# for i in tail('a.txt.py'):
# print(i)
转载于:https://www.cnblogs.com/575dsj/p/7050251.html