Сторожевой таймер трижды получает события в Python 3

Я создаю программу на 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()

Затем я заметил нечто странное. Я установил сторожевой таймер для 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

Мне интересно, что может вызвать такое поведение и как я могу это исправить.

Этот вопрос не является дубликатом:


person PurkkaKoodari    schedule 30.09.2015    source источник
comment
Проблема зарегистрирована в репозитории Github: github.com/gorakhargosh/watchdog/issues/346   -  person bastula    schedule 11.04.2016
comment
Не могли бы вы поделиться дополнительной информацией о среде, которую вы используете? (какая версия python 3, какая версия python 2, ОС и т. д.) вы изменяете сам скрипт в этом примере? что за модификация? Это также происходит, когда вы передаете путь к сценарию? Это означает, что отслеживаемый путь не является «.».   -  person Alonme    schedule 14.12.2019
comment
@Alonme Сценарий не был изменен, когда я запускал его в 2015 году. Проблема больше не возникает. Я только что попробовал Python 3.7/3.8 и все версии сторожевого таймера от 0.8.0 до 0.10.0. В настоящее время я использую Debian Bullseye с Linux 5.2.0, не могу сказать, что я использовал в 2015 году.   -  person PurkkaKoodari    schedule 14.12.2019