代码改变世界

Pytho实现tail -f

2014-11-03 12:20  cmsd  阅读(542)  评论(0编辑  收藏  举报

实现Python版的tail -f功能

tail -f 的功能非常好用。我们用Python也可以实现这样的功能。
实现的原理是通过Python版本的inotify获得文件的更新消息,从而读取更新的行。pyinotify的下载地址https://github.com/seb-m/pyinotify
下载解压后得到如下文件
#ls
ACKS  build  common  COPYING  dist  MANIFEST.in  old  python2  python3  README.md  setup.py
执行如下命令进行安装。
python setup.py build
python setup.py install
然后就可以使用Python版本的inotify功能了。
下面是我写的一个简单的tail -f文件的实现。
#!/usr/bin/python

import pyinotify
import time
import os
class ProcessTransientFile(pyinotify.ProcessEvent):
    def process_IN_MODIFY(self, event):
        line = file.readline()
        if line:
            print line, # already has newline

filename = '/tmp/test1234'
file = open(filename,'r')
#Find the size of the file and move to the end
st_results = os.stat(filename)
st_size = st_results[6]
file.seek(st_size)

wm = pyinotify.WatchManager()
notifier = pyinotify.Notifier(wm)
wm.watch_transient_file(filename, pyinotify.IN_MODIFY, ProcessTransientFile)
notifier.loop()

 


tail的文件为/tmp/test1234,通过向/tmp/test1234写入内容,可以看到python脚本可以动态显示更新的内容。
这个小脚本只是抛砖引玉。通过监听文件,尤其是日志文件可以实现很多诸如报警、自动控制等功能。
 
本文转自 “http://www.opstool.com/article/226”