1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
#/usr/bin/env python #-*- coding=utf-8 -*- pos = 0 while True : con = open ( "a.txt" ) if pos ! = 0 : con.seek(pos, 0 ) while True : line = con.readline() if line.strip(): print line.strip() pos = pos + len (line) if not line.strip(): break con.close() |
利用工具pyinotify监控文件内容变化,当文件逐渐变大时,可轻松完成任务:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
#!/usr/bin/env python #-*- coding=utf-8 -*- import os import datetime import pyinotify import logging pos = 0 def printlog(): global pos try : fd = open ( "log/a.txt" ) if pos ! = 0 : fd.seek(pos, 0 ) while True : line = fd.readline() if line.strip(): print line.strip() pos = pos + len (line) if not line.strip(): break fd.close() except Exception,e: print str (e) class MyEventHandler(pyinotify.ProcessEvent): def process_IN_MODIFY( self ,event): try : printlog() except Exception,e: print str (e) def main(): printlog() wm = pyinotify.WatchManager() wm.add_watch( "log/a.txt" ,pyinotify.ALL_EVENTS,rec = True ) eh = MyEventHandler() notifier = pyinotify.Notifier(wm,eh) notifier.loop() if __name__ = = "__main__" : main() |
原文链接:http://blog.51cto.com/guoshiwei/2124306