65

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

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()

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

4

3 に答える 3

119

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

于 2013-09-03T18:48:40.877 に答える
0

datetime の代わりに、src_path チェック ロジックを使用できます。これは、1 秒を超える datetime ロジックをチェックした後のロジックが失敗するためです。

class EventHandler(FileSystemEventHandler):
    def __init__(self):
        self.src_path = ''

    def on_modified(self, event):
        if self.src_path == event.src_path:
            return
        else:
            self.src_path = event.src_path
        logger.info(f"{event.event_type} occured on file {self.src_path}")
        #your long processing logics goes here.
于 2021-02-05T16:17:39.523 に答える