在Ubuntu上运行,每次创建文件时,我都会获得修改后的事件。
这是设计还是我做错了什么?
我正在使用事件处理程序类PatternMatchingEventHandler
event_handler = MediaFileHandler(ignore_directories=True)
observer = Observer()
observer.schedule(event_handler, path=directory, recursive=True)
observer.start()
如果这是正确的行为,我可以安全地忽略创建的事件吗?
答案 0 :(得分:9)
简短回答:f = open(... , 'w')
生成FileCreatedEvent
,f.flush()
或f.close()
可生成FileModifiedEvent
。所以,是的,创建文件通常会同时生成FileCreatedEvent
和FileModifiedEvents
。
您是否可以安全地忽略FileCreatedEvents取决于您要执行的操作。如果您有兴趣在创建文件时做出反应,那么您需要处理FileCreatedEvents,并且可能忽略FileModifiedEvents,因为在修改文件时可以生成FileModifiedEvents而不生成FileCreatedEvents。
使用规范的看门狗脚本(下面),所有都应该更清楚。
答案很长:要了解正在发生的事情,请运行规范监督程序straight from the docs:
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()
来自终端:
% mkdir ~/tmp
% cd ~/tmp
% script.py
当您以w
模式打开文件时,现在使用Python解释器:
In [126]: f = open('/home/unutbu/tmp/foobar', 'w')
终端打印
2014-02-05 16:29:34 - <FileCreatedEvent: src_path=/home/unutbu/tmp/foobar>
当您写入文件时,看门狗不会报告任何事件:
In [127]: f.write('Hi')
但是当你冲洗时,
In [128]: f.flush()
报告FileModifiedEvent:
2014-02-05 16:29:55 - <FileModifiedEvent: src_path=/home/unutbu/tmp/foobar>
如果你在文件中写了更多东西:
In [129]: f.write(' there')
类似地,当您关闭文件时会报告FileModifiedEvent,因为更多的输出被刷新到磁盘:
In [130]: f.close()
2014-02-05 16:30:12 - <FileModifiedEvent: src_path=/home/unutbu/tmp/foobar>