Python生成器yield应用实例——监控日志
Python生成器yield是编写基于处理管道,流或数据流程序的一种极其强大的方式,在《Python参考手册》中有一则实例非常简单实用,略加修改,分享一下给大家。
需要分析
假设服务器有一个日志文件,每隔一秒都会更新日志的内容,日志每行中都有一组类似:2017-12-21 14:07:26.471691 99123数据被写入日志。
我们的目的是分析日志中的数字如果大于5000就要打印出来。
这样来看,我们需要一个程序负责模拟日志写入,另一个程序负责分析日志打印数据。
模拟日志写入
server_log.py:
import random
from datetime import *
import os
import time
def server_log():
# 生成模拟的日志数据
server_int = random.randint(1,99999)#生成需要的随机数
server_date = datetime.now()#获取当前系统时间
return str(server_date) + ' ' + str(server_int)#拼装日志字符串
while True:
#模拟系统写入日志
#打开日志文件并写入日志
with open(os.path.join(os.path.dirname(__file__),'server_log.log'),'at') as f :
s = server_log()
print(s)
f.write(s + '\n')
time.sleep(1)
上边的代码我已经添加了相关的注释,这样我们就有了一个日志文件,每秒会有一第记录插入到日志中。
利用生成器yield解析日志
生成器可以返回一个迭代的流式的对象,我们可以通过这种方式便捷的获得相关数据,而且代码也更清晰易懂
tail.py 代码如下:
import time
def tail(f):
f.seek(0,2)#移动到文件尾部。
while True:
line = f.readline()
if not line :
time.sleep(1)
continue
yield line
def grep(lines):
for l in lines:
k = int(l.split()[2])
if k >50000:
yield l
serverlog = tail(open('server_log.log'))
lines = grep(serverlog)
for line in lines:
print(line)
我们运行两个文件看下效果:

代码虽然简单,但值得细细品味,感受python的简约与强大吧。
本文源码下载:
本文为原创文章,遵循: CC BY-NC-SA 4.0版权协议。
本文链接:https://www.suiyan.cc/blog/68
标签: Python基础
相关文章
- 解决错误 ERROR [WinError 10049] 在其上下文中,该请求的地址无效。
- 如何在Python程序中使用配置文件.ini(ConfigParser)
- Python os.mknod 运行报错无法创建文件
- Python os.path.dirname(__file__) 在终端命令行下报错
- 聊聊Python中的递归与快速排序那点事
- 妙用IPython学习Python--IPython快速上手
- 如何快速的复习学习过的Python
- python中导入不同目录中的自定义模块/class/函数/方法
- 浅谈Python中的协程及利用协程代替多线程及多进程并发编程
- 聊聊Python中晦涩的生成器(yield)与生成器表达式
- Python中创建TCP服务器与客户端进行通信(下)Tk、thread与socket组合。
- Python中创建TCP服务器与客户端进行通信(上)
- Python程序在Windows10终端运行中文乱码解决方法
- 你与黑客之间差了多少行Python代码?
- 聊聊Python闭包(Closure)的那点事。
- Python并发编程(下)功能强大设置简单的分布式多进程生产者与消费者模式
- Python并发编程(上)进程模块multiprocessing模块和Process类
- Python多线程编程(下)多线程锁 threading.Lock
- Python多线程编程(上)多线程创建的几种方法
- python 类的静态方法和类方法
- Python面向对象编程(OOP)初探
- Python random 随机数模块操作总结
- Python3 datetime模块的时间操作
- python3函数学习笔记简单总结
- PythonINI配置文件读写的简单方法
- Python open()函数文件打开、读、写操作总结
- Python os.path模块中一些常用方法的整理总结
- Python 采集数据三步曲之[Requests + re.py模块进行数据采集]
- Python 采集数据三步曲之[Requests开源协议的HTTP 库]
- Python 采集数据三步曲之[正则表达式 re.py]
- python3 Markdown模块解析Markdown代码
- 创建python 虚拟环境 venv