python模拟linux中grep功能

#!/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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值