我需要查看日志文件以了解更改。翻了一下stackoverflow的问题,看到有人推荐
watchdog
。所以我正在尝试测试,但不确定在文件更改时添加代码的位置:
import time
from watchdog.observers import Observer
from watchdog.events import LoggingEventHandler
if __name__ == "__main__":
event_handler = LoggingEventHandler()
observer = Observer()
observer.schedule(event_handler, path='.', recursive=False)
observer.start()
try:
while True:
time.sleep(1)
else:
print "got it"
except KeyboardInterrupt:
observer.stop()
observer.join()
如果文件已添加/更改,我在哪里添加“知道了”——在
while
循环中?
而不是
LoggingEventHandler
定义你的处理程序:
#!/usr/bin/python
import time
from watchdog.observers import Observer
from watchdog.events import FileSystemEventHandler
class MyHandler(FileSystemEventHandler):
def on_modified(self, event):
print(f'event type: {event.event_type} path : {event.src_path}')
if __name__ == "__main__":
event_handler = MyHandler()
observer = Observer()
observer.schedule(event_handler, path='/data/', recursive=False)
observer.start()
try:
while True:
time.sleep(1)
except KeyboardInterrupt:
observer.stop()
observer.join()
on_modified
在修改文件或目录时调用。
这里有一个片段可以防止它像其他人在@alecxe 回答中评论的那样运行两次:
from datetime import datetime, timedelta
class MyHandler(FileSystemEventHandler):
def __init__(self):
self.last_modified = datetime.now()
def on_modified(self, event):
if datetime.now() - self.last_modified < timedelta(seconds=1):
return
else:
self.last_modified = datetime.now()
print(f'Event type: {event.event_type} path : {event.src_path}')
print(event.is_directory) # This attribute is also available
您可以使用 src_path 检查逻辑而不是日期时间,因为如果检查超过 1 秒的日期时间逻辑之后的逻辑将失败。
class EventHandler(FileSystemEventHandler):
def __init__(self):
self.src_path = ''
def on_modified(self, event):
if self.src_path == event.src_path:
return
else:
self.src_path = event.src_path
logger.info(f"{event.event_type} occured on file {self.src_path}")
#your long processing logics goes here.
对于其他遇到这个问题并想要答案的人:“如何观看特定文件”,@Cmag 也提出了这个问题,这是一种观看特定文件的快速方法。您将特定文件设置为正则表达式并使用
directory_to_watch = './'
event_handler = RegexMatchingEventHandler(regexes=['.*/config.json'])
observer = Observer()
observer.schedule(event_handler, directory_to_watch, recursive=False)
observer.start()
try:
while True:
time.sleep(1)
finally:
observer.stop()
observer.join()
如何使用 watchdog 集成相同的功能,但使用 fastAPI
所以当文件夹被修改时,fastapi会执行一个过程。