我已从以下网站复制了Python看门狗脚本:https://www.michaelcho.me/article/using-pythons-watchdog-to-monitor-changes-to-a-directory
import time
from watchdog.observers import Observer
from watchdog.events import FileSystemEventHandler
class Watcher:
DIRECTORY_TO_WATCH = "/path/to/my/directory"
def __init__(self):
self.observer = Observer()
def run(self):
event_handler = Handler()
self.observer.schedule(event_handler, self.DIRECTORY_TO_WATCH, recursive=True)
self.observer.start()
try:
while True:
time.sleep(5)
except:
self.observer.stop()
print "Error"
self.observer.join()
class Handler(FileSystemEventHandler):
@staticmethod
def on_any_event(event):
if event.is_directory:
return None
elif event.event_type == 'created':
# Take any action here when a file is first created.
print "Received created event - %s." % event.src_path
# Build up queue of subtasks here and let another thread/process
# take care of it so that main process can continue.
elif event.event_type == 'modified':
# Taken any action here when a file is modified.
print "Received modified event - %s." % event.src_path
if __name__ == '__main__':
w = Watcher()
w.run()
此脚本对我来说非常有用,但是我还有一些其他要求。
除了打印文本,我想开始一个可能需要几分钟的附加过程(Python脚本)。主脚本不应等待该过程完成,而应继续检查新文件或更改的文件。
开始的辅助进程不允许彼此超越,因此必须放在需要串行处理的某种队列中。
哪种方法/软件包是解决这些要求的好方法?我已经简要介绍了多处理和异步,但是不确定正确的实现方式。
我的一般想法是,应根据事件类型启动一个单独的进程/线程,该事件/线程检查队列并一个接一个地进行。理想情况下,当主进程关闭时,该辅助线程/进程将完成剩余的队列。
答案 0 :(得分:0)
我将此模板用于看门狗。 on_any_event
对我来说有点敏感。
答案为1 .:您可以将任何内容替换为print
。函数,方法,循环等。Watcher
将继续运行并在事件发生时调用Handler()
。
在调用on_any_event
之后,您需要详细说明您想做的事情。
class Handler(FileSystemEventHandler):
@staticmethod
def on_any_event(event):
if event.is_directory:
return None
elif event.event_type == 'created':
return run_function()
elif event.event_type == 'modified':
return run_other_function()
def run_function():
W = '36 Chambers\n'
with open('Wu-Tang.txt', '') as wu:
wu.write(W)
wu.close()
def run_other_function():
_W = 'The RZA the GZA.\n'
with open('Wu-Tang.txt', 'a') as _wu:
_wu.write(_W)
_wu.close()
if __name__ == '__main__':
w = Watcher()
w.run()