通八洲科技

Python文件系统监控工具_变更解析【教程】

日期:2026-01-02 00:00 / 作者:舞夢輝影
Python监控文件系统变更最常用稳定方案是watchdog库,它跨平台、支持递归监听、事件粒度细且异步友好;安装后可监听创建、修改、删除等7类事件,并通过路径过滤、去重和限定递归层级优化性能。

Python中监控文件系统变更,最常用且稳定的方案是使用 watchdog 库。它跨平台(Windows/macOS/Linux)、支持递归监听、事件粒度细(创建、修改、删除、重命名等),并且设计为异步友好,适合集成进脚本或服务中。

安装与基础监听

通过 pip 安装:

pip install watchdog

最小可用示例:监听当前目录下所有文件变动

from watchdog.observers import Observer
from watchdog.events import FileSystemEventHandler

class MyHandler(FileSystemEventHandler):
    def on_modified(self, event):
        if not event.is_directory:
            print(f"文件被修改: {event.src_path}")

observer = Observer()
observer.schedule(MyHandler(), path=".", recursive=True)
observer.start()
try:
    while True:
        pass
except KeyboardInterrupt:
    observer.stop()
observer.join()

关键事件类型与用途

watchdog 提供 7 类核心事件,按实际需求选择重写对应方法:

避免重复触发与性能优化

文本编辑器(如 VS Code、Sublime)保存时可能先写临时文件再原子替换,导致多个事件;高频日志写入也可能刷屏。建议:

实战:监听配置文件自动重载

常见需求:config.yaml 修改后,程序自动加载新配置。可结合 threading.Event 或 queue.Queue 实现安全通信:

import yaml
from watchdog.events import FileSystemEventHandler

class ConfigReloader(FileSystemEventHandler):
    def __init__(self, config_path, reload_callback):
        self.config_path = config_path
        self.reload_callback = reload_callback

    def on_modified(self, event):
        if event.src_path == self.config_path:
            try:
                with open(self.config_path) as f:
                    new_cfg = yaml.safe_load(f)
                self.reload_callback(new_cfg)
            except Exception as e:
                print(f"配置加载失败: {e}")

将该 handler 绑定到 Observer 即可实现热更新,无需重启进程。