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:
JavaScript
x
18
18
1
import time
2
from watchdog.observers import Observer
3
from watchdog.events import LoggingEventHandler
4
5
if __name__ == "__main__":
6
event_handler = LoggingEventHandler()
7
observer = Observer()
8
observer.schedule(event_handler, path='.', recursive=False)
9
observer.start()
10
try:
11
while True:
12
time.sleep(1)
13
else:
14
print "got it"
15
except KeyboardInterrupt:
16
observer.stop()
17
observer.join()
18
Where do I add the “got it” — in the while
loop if the files have been added/changed?
Advertisement
Answer
Instead of LoggingEventHandler
define your handler:
JavaScript
1
24
24
1
#!/usr/bin/python
2
import time
3
from watchdog.observers import Observer
4
from watchdog.events import FileSystemEventHandler
5
6
7
class MyHandler(FileSystemEventHandler):
8
def on_modified(self, event):
9
print(f'event type: {event.event_type} path : {event.src_path}')
10
11
12
if __name__ == "__main__":
13
event_handler = MyHandler()
14
observer = Observer()
15
observer.schedule(event_handler, path='/data/', recursive=False)
16
observer.start()
17
18
try:
19
while True:
20
time.sleep(1)
21
except KeyboardInterrupt:
22
observer.stop()
23
observer.join()
24
on_modified
is called when a file or directory is modified.