Watchdog получает события трижды в Python 3
Я создаю программу на Python, используяСторожевая собака который просматривает набор файлов и выполняет действия на основе изменений. я кладуточный пример с их сайта в файле:
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()
Затем я заметил нечто странное. Я установил сторожевой таймер для Python 2 и Python 3, одинаково (используяpip2 install watchdog
а такжеpip3 install watchdog
) и в то же время. Однако, когда я запускаю программу в Python 2 и 3 и делаю ту же модификациюодин раз для каждого это происходит:
$ python2 watch_test.py
2015-09-30 11:18:32 - Modified file: ./watch_test.py
$ python3 watch_test.py
2015-09-30 11:18:39 - Modified file: ./watch_test.py
2015-09-30 11:18:39 - Modified file: ./watch_test.py
2015-09-30 11:18:39 - Modified file: ./watch_test.py
Что мне интересно, так это то, что может вызвать такое поведение и как я могу это исправить.
Этот вопросне является дубликат:
сторожевой таймер питона запускается более одного раза; события все одинаковыеПовторяющиеся события сторожевого таймера Python; ошибка происходит только на Python 3, а не на Python 2.