【问题标题】:watchdog monitoring file for changes看门狗监控文件的变化
【发布时间】:2013-09-07 02:30:37
【问题描述】:

我需要查看日志文件的更改。在查看了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 循环中?

【问题讨论】:

  • 使用来自 github 的示例
  • github上的例子还是不行。

标签: python file file-io monitoring watchdog


【解决方案1】:

定义你的处理程序而不是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在文件或目录被修改时被调用。

【讨论】:

  • 太好了,谢谢!现在我如何只看一个特定的文件,现在看整个目录?
  • 不客气。您可以查看包含该文件的目录,然后在处理程序方法中检查 event.src_path 变量。
  • 这段代码锁定了文件,所以不能被其他程序使用
  • @DanTenenbaum 你有没有发现如何修复重复的“知道了”消息?我也收到了两条连续的消息。
  • observer.join() 在代码中做了什么?观察者也有自己的线程还是在主线程中运行(试图弄清楚为什么 time.sleep(1) 调用会起作用,因为观察者似乎使用线程)?看门狗文档似乎有点稀疏,所以试图拼凑如何使用这个东西......
【解决方案2】:

这是一个 sn-p,以防止它运行两次,因为其他人在 @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

【讨论】:

  • 谢谢你 - 正是我正在寻找的,如果你仍然活跃,你能在这里回答我的 Q 吗(实际上这个 Q 回答了大部分问题),我会用绿色打勾:stackoverflow.com/questions/57531818/…
  • 打印语句 print(f'Event type: {event.event_type} path : {event.src_path}') 给出错误?我将其更改为 print(event.event_type) print(event.src_path) print(event.is_directory) 也许有人可以澄清原因?
  • @Cat,您使用的是 Pythonrealpython.com/python-f-strings 他们很棒!
  • 如果只有一个文件,这很好。但是如果目录中有多个文件,这可以对用户隐藏事件。
【解决方案3】:

您可以使用 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.

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2023-03-29
    • 2018-01-08
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多