Python使用pyinotify模拟tail命令,pyinotifytail,tail -f 的功能非


tail -f 的功能非常好用。我们用Python也可以实现这样的功能。

实现的原理是通过Python版本的inotify获得文件的更新消息,从而读取更新的行。pyinotify的下载地址https://github.com/seb-m/pyinotify

下载解压后得到如下文件

#lsACKS  build  common  COPYING  dist  MANIFEST.in  old  python2  python3  README.md  setup.py 

执行如下命令进行安装。

python setup.py buildpython setup.py install 

然后就可以使用Python版本的inotify功能了。下面是我写的一个简单的tail -f文件的实现。

import pyinotifyimport timeimport osclass ProcessTransientFile(pyinotify.ProcessEvent):    def process_IN_MODIFY(self, event):        line = file.readline()        if line:            print line, # already has newlinefilename = '/tmp/test1234'file = open(filename,'r')#Find the size of the file and move to the endst_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脚本可以动态显示更新的内容。这个小脚本只是抛砖引玉。通过监听文件,尤其是日志文件可以实现很多诸如报警、自动控制等功能

评论关闭