4

Я пытаюсь использовать watchdog для запуска скрипта синхронизации всякий раз, когда что-либо изменяется в каталоге (кроме одного конкретного файла). Я просто скопировал код из readme (вставил ниже), что делает то, что он говорит; журнал, файл которого изменился.Как запустить функцию, когда что-либо изменяется в каталоге с Python Watchdog?

import sys 
import time 
import logging 
from watchdog.observers import Observer 
from watchdog.events import LoggingEventHandler 

if __name__ == "__main__": 
    logging.basicConfig(level=logging.INFO, 
         format='%(asctime)s - %(message)s', 
         datefmt='%Y-%m-%d %H:%M:%S') 
    path = sys.argv[1] if len(sys.argv) > 1 else '.' 
    event_handler = LoggingEventHandler() 
    observer = Observer() 
    observer.schedule(event_handler, path, recursive=True) 
    observer.start() 
    try: 
     while True: 
      time.sleep(1) 
    except KeyboardInterrupt: 
     observer.stop() 
    observer.join() 

Теперь я хочу, чтобы запустить функцию (которая синхронизирует всю папку на удаленный компьютер), если что-либо изменения. Поэтому я просто заменил event_handler своей собственной функцией. Но это дает мне следующую ошибку:

Traceback (most recent call last): 
    File "/System/Library/Frameworks/Python.framework/Versions/2.7/lib/python2.7/threading.py", line 810, in __bootstrap_inner 
    self.run() 
    File "/Library/Python/2.7/site-packages/watchdog/observers/api.py", line 199, in run 
    self.dispatch_events(self.event_queue, self.timeout) 
    File "/Library/Python/2.7/site-packages/watchdog/observers/api.py", line 368, in dispatch_events 
    handler.dispatch(event) 
AttributeError: 'function' object has no attribute 'dispatch' 

Кто-нибудь знает, что я делаю неправильно здесь? Все советы приветствуются!

пс. Я также хочу, чтобы один файл в папке не просматривался. Любые идеи, как я должен это делать?

ответ

10

Вы должны подклассы и делать все, что вы хотите в отправке:

import sys 
import time 
import logging 
from watchdog.observers import Observer 
from watchdog.events import LoggingEventHandler 

class Event(LoggingEventHandler): 
    def dispatch(self, event): 
     print("Foobar") 

if __name__ == "__main__": 
    logging.basicConfig(level=logging.INFO, 
         format='%(asctime)s - %(message)s', 
         datefmt='%Y-%m-%d %H:%M:%S') 
    path = sys.argv[1] if len(sys.argv) > 1 else '.' 
    event_handler = Event() 
    observer = Observer() 
    observer.schedule(event_handler, path, recursive=True) 
    observer.start() 
    try: 
     while True: 
      time.sleep(1) 
    except KeyboardInterrupt: 
     observer.stop() 
    observer.join() 

Если вы запустите код, который вы увидите Foobar выводится всякий раз, когда обнаруживается изменение, игнорировать файлы, которые вы, возможно, придется использовать [события. PatternMatchingEventHandler] [1]. Существуют различные методы в каждом

Чтобы сделать что-то когда-то модифицирована случай мы можем переопределить on_modified:

class Event(LoggingEventHandler): 
    def on_modified(self, event): 
     print("Doh") 

и запустить код, используя класс выше event_handler = Event() и изменение файла будет что-то вроде:

Doh 
Doh 
Doh 
Doh 
Doh 
Doh 
Doh 
2015-10-03 15:33:55 - Created file: ./test.txt___jb_bak___ 
2015-10-03 15:33:55 - Moved file: from ./test.txt to ./test.txt___jb_old___ 
2015-10-03 15:33:55 - Moved file: from ./test.txt___jb_bak___ to ./test.txt 
2015-10-03 15:33:55 - Deleted file: ./test.txt___jb_old___ 
Doh 

[1]: http://pythonhosted.org/watchdog/api.html#watchdog.events.PatternMatchingEventHandlerEventHandler класс вы можете переопределить, все это зависит от того, что именно вы хотите сделать. LoggingEventHandler класс itslef подкласс watchdog.events.FileSystemEventHandler:

класс watchdog.events.FileSystemEventHandler Основы: объект

Base file system event handler that you can override methods from. 

отправка (событие) отправляет события соответствующие методы.

Parameters: event (FileSystemEvent) – The event object representing the file system event. 

on_any_event (событие) всеохватывающий обработчик события.

Parameters: event (FileSystemEvent) – The event object representing the file system event. 

on_created (событие) Вызывается, когда файл или каталог создается.

Parameters: event (DirCreatedEvent or FileCreatedEvent) – Event representing file/directory creation. 

on_deleted (событие) Вызывается, когда файл или каталог удаляется.

Parameters: event (DirDeletedEvent or FileDeletedEvent) – Event representing file/directory deletion. 

on_modified (событие) Вызывается, когда файл или каталог изменен.

Parameters: event (DirModifiedEvent or FileModifiedEvent) – Event representing file/directory modification. 

on_moved (событие) Вызывается, когда файл или каталог был перемещен или переименован.

Parameters: event (DirMovedEvent or FileMovedEvent) – Event representing file/directory movement.