Folks, I have a need to watch a log file for changes. After looking through stackoverflow questions, I see people recommending 'watchdog'. So i'm trying to test, and am not sure where to add the code for when files change:

#!/usr/bin/python

import time

from watchdog.observers import Observer

from watchdog.events import LoggingEventHandler

if __name__ == "__main__":

event_handler = LoggingEventHandler()

observer = Observer()

observer.schedule(event_handler, path='.', recursive=False)

observer.start()

try:

while True:

time.sleep(1)

else:

print "got it"

except KeyboardInterrupt:

observer.stop()

observer.join()

Where do I add the "got it", in the while loop if the files have been added/changed?

解决方案

Instead of LoggingEventHandler define your handler:

#!/usr/bin/python

import time

from watchdog.observers import Observer

from watchdog.events import FileSystemEventHandler

class MyHandler(FileSystemEventHandler):

def on_modified(self, event):

print(f'event type: {event.event_type} path : {event.src_path}')

if __name__ == "__main__":

event_handler = MyHandler()

observer = Observer()

observer.schedule(event_handler, path='/data/', recursive=False)

observer.start()

try:

while True:

time.sleep(1)

except KeyboardInterrupt:

observer.stop()

observer.join()

on_modified is called when a file or directory is modified.

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐