Cão de guarda recebendo eventos três vezes em Python 3

Estou criando um programa em Python usandoCão de guarda que assiste a um conjunto de arquivos e executa ações com base em alterações. Eu colocoo exemplo exato do site em um arquivo:

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

Então, notei algo estranho. Instalei o watchdog para Python 2 e Python 3, da mesma maneira (usandopip2 install watchdog epip3 install watchdog), e ao mesmo tempo. No entanto, quando executo o programa em Python 2 e 3 e faço a mesma modificaçãouma vez para cada um, isso acontece:

$ 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

O que eu quero saber é o que poderia causar esse comportamento e como eu poderia corrigi-lo.

Essa questãonão é uma duplicata de:

watchdog python é executado mais de uma vez; os eventos são todos iguaisEventos duplicados do watchdog do Python; o erro ocorre apenas no Python 3, não no Python 2.

questionAnswers(0)

yourAnswerToTheQuestion