私は 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
ときに実行したい単なるシェル スクリプトです。.done
/path/to/some/directory/bin
#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)"
ただし、 a を発行してからonpython observer.py
を実行すると、シェル スクリプトが 1 回ではなく 3 回実行されることがわかります。touch job.done
/path/to/some/directory/bin
./run.sh
これが1回だけでなく3回実行される理由がわかりません(job.done
bashスクリプトでファイルを削除します)