web-dev-qa-db-ja.com

python変更のためのウォッチドッグ監視ファイル

皆さん、ログファイルの変更を監視する必要があります。 stackoverflowの質問に目を通した後、「ウォッチドッグ」を推奨する人々がいます。だから私はテストしようとしていますが、ファイルが変更されたときにコードを追加する場所がわかりません:

#!/usr/bin/python
import time
from watchdog.observers import Observer
from watchdog.events import LoggingEventHandler

if __== "__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()

ファイルが追加/変更された場合、whileループのどこに "got it"を追加しますか?

46
Cmag

LoggingEventHandlerの代わりに、ハンドラーを定義します。

#!/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 __== "__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は、ファイルまたはディレクトリが変更されたときに呼び出されます。

94
alecxe

他の人が@alecxeの回答でコメントしているように、2回実行されるのを防ぐためのスニペットがあります:

from datetime import datetime, timedelta

class MyHandler(FileSystemEventHandler):
    def __init__(self):
        self.last_modified = datetime.now()

    def on_modified(self, event):
        if datetime.now() - self.last_modified < timedelta(seconds=1):
            return
        else:
            self.last_modified = datetime.now()
        print(f'Event type: {event.event_type}  path : {event.src_path}')
        print(event.is_directory) # This attribute is also available
2
run_the_race