簡體   English   中英

python看門狗運行不止一次

[英]python watchdog runs more than once

我正在嘗試學習python-watchdog,但我有點困惑為什么我設置的工作運行不止一次。 所以,這是我的設置:

#handler.py
import os
from watchdog.events import FileSystemEventHandler
from actions import run_something

def getext(filename):
    return os.path.splitext(filename)[-1].lower()

class ChangeHandler(FileSystemEventHandler):

    def on_any_event(self, event):

        if event.is_directory:
            return
        if getext(event.src_path) == '.done':
            run_something()
        else: 
            print "event not directory.. exiting..."
            pass

觀察者的設置如下:

#observer.py
import os
import time
from watchdog.observers import Observer
from handler import ChangeHandler

BASEDIR = "/path/to/some/directory/bin"

def main():

    while 1:

        event_handler = ChangeHandler()
        observer = Observer()
        observer.schedule(event_handler, BASEDIR, recursive=True)
        observer.start()
        try:
            while True:
                time.sleep(1)
        except KeyboardInterrupt:
            observer.stop()
        observer.join()

 if __name__ == '__main__':
    main()

最后,這樣的行為:

#actions.py
import os
import subprocess

def run_something():
    output = subprocess.check_output(['./run.sh'])
    print output
    return None

..where ./run.sh只是一個shell腳本我想在/path/to/some/directory/bin上找到擴展名為.done的文件時運行

#run.sh
#!/bin/bash
echo "Job Start: $(date)"
rm -rf /path/to/some/directory/bin/job.done # remove the .done file
echo "Job Done: $(date)"

但是,當我發出一個python observer.py然后在/path/to/some/directory/bin上執行touch job.done時,我看到我的shell腳本./run.sh運行了三次而不是一次..

我很困惑,為什么這個運行三次而不只是一次(我確實刪除了我的bash腳本上的job.done文件)

要調試監視程序腳本,打印看門狗所看到的事件是很有用的。 一個文件編輯或CLI命令(例如touch )可能導致多個監視程序事件。 例如,如果插入print語句:

class ChangeHandler(FileSystemEventHandler):

    def on_any_event(self, event):
        print(event)

記錄每個事件,運行

% touch job.done

生成

2014-12-24 13:11:02 - <FileCreatedEvent: src_path='/home/unutbu/tmp/job.done'>
2014-12-24 13:11:02 - <DirModifiedEvent: src_path='/home/unutbu/tmp'>
2014-12-24 13:11:02 - <FileModifiedEvent: src_path='/home/unutbu/tmp/job.done'>

上面有兩個事件src_path在結束job.done 從而,

    if getext(event.src_path) == '.done':
        run_something()

運行兩次,因為有一個FileCreatedEvent和一個FileModifiedEvent 你可能最好只監控FileModifiedEvent

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM