Python自动监控文件夹:新增文件实时归类+微信通知

部署运行你感兴趣的模型镜像

一、为什么需要文件监控自动化?

在日常工作中,你是否经常遇到这样的困扰:

  • 同事发来的文件混杂在下载文件夹里,需要手动整理
  • 重要文件被修改却没能及时察觉
  • 紧急合同上传后,需要反复刷新查看是否到位

传统方式 vs 自动化方案对比​:

方式响应速度准确性持续工作能力
人工检查分钟级依赖注意力8小时/天
Python监控秒级100%​24小时/天

二、核心技术:Watchdog库详解

1. 基础监控实现

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

class MyHandler(FileSystemEventHandler):
    def on_created(self, event):
        print(f'新文件出现: {event.src_path}')
        # 这里添加文件处理逻辑

if __name__ == "__main__":
    path = "C:/监控文件夹"  # 替换为你的监控路径,比如微信文件存储路径,各类下载文件夹等
    event_handler = MyHandler()
    observer = Observer()
    observer.schedule(event_handler, path, recursive=True)
    observer.start()
    
    try:
        while True:
            time.sleep(1)
    except KeyboardInterrupt:
        observer.stop()
    observer.join()

关键参数说明​:

  • recursive=True:监控子文件夹
  • event.src_path:获取文件完整路径
  • on_created:响应文件创建事件(还有on_modified, on_deleted等)

2. 增强功能:文件智能分类

def auto_classify(file_path):
    """根据扩展名自动分类文件"""
    from pathlib import Path
    import shutil
    
    ext_map = {
        '.pdf': '文档',
        '.jpg': '图片',
        '.xlsx': '表格'
    }
    
    file = Path(file_path)
    if file.is_file():
        ext = file.suffix.lower()
        target_dir = Path(file.parent) / ext_map.get(ext, '其他')
        target_dir.mkdir(exist_ok=True)
        shutil.move(str(file), target_dir)
        return target_dir / file.name

分类规则扩展建议​:

  • 按项目名称分类(从文件名提取关键词)
  • 按文件大小分类(大文件单独存放)
  • 按修改日期分类(自动归档旧文件)

三、微信实时通知实现

1. 通过Server酱推送

import requests

def wechat_notify(title, content):
    """发送微信通知"""
    SCKEY = "你的Server酱SCKEY"  # 在https://sct.ftqq.com申请
    url = f"https://sc.ftqq.com/{SCKEY}.send"
    data = {
        "text": title,
        "desp": content
    }
    requests.post(url, data=data)

2. 企业微信机器人通知

def qywx_notify(content):
    """企业微信机器人通知"""
    webhook = "你的企业微信群机器人Webhook地址"
    headers = {'Content-Type': 'application/json'}
    data = {
        "msgtype": "text",
        "text": {
            "content": content,
            "mentioned_mobile_list": ["13800138000"]  # 需要@的人
        }
    }
    requests.post(webhook, headers=headers, json=data)

通知内容优化建议​:

  • 包含文件类型、大小、修改时间
  • 添加快速访问链接(局域网路径)
  • 重要文件变更@特定人员

四、完整实战案例

1. 监控+分类+通知完整代码

import time
from watchdog.observers import Observer
from watchdog.events import FileSystemEventHandler
from pathlib import Path
import shutil
import requests

class SmartFileHandler(FileSystemEventHandler):
    def __init__(self):
        self.ext_map = {
            '.pdf': '文档',
            '.docx': '文档',
            '.xlsx': '表格',
            '.jpg': '图片'
        }
    
    def on_created(self, event):
        file_path = event.src_path
        if Path(file_path).is_file():
            target_path = self.classify_file(file_path)
            self.send_notification(file_path, target_path)
    
    def classify_file(self, file_path):
        """文件自动分类"""
        file = Path(file_path)
        ext = file.suffix.lower()
        target_dir = Path(file.parent) / self.ext_map.get(ext, '其他')
        target_dir.mkdir(exist_ok=True)
        shutil.move(str(file), target_dir)
        return target_dir / file.name
    
    def send_notification(self, origin_path, target_path):
        """发送微信通知"""
        file = Path(origin_path)
        msg = f"📁 新文件提醒\n\n" \
              f"文件名:{file.name}\n" \
              f"类型:{file.suffix}\n" \
              f"大小:{file.stat().st_size/1024:.2f}KB\n" \
              f"存放位置:{target_path}"
        wechat_notify("文件监控提醒", msg)

def main():
    path = "C:/监控文件夹"  # 设置监控路径
    event_handler = SmartFileHandler()
    observer = Observer()
    observer.schedule(event_handler, path, recursive=True)
    observer.start()
    
    print(f"开始监控文件夹: {path}")
    try:
        while True:
            time.sleep(1)
    except KeyboardInterrupt:
        observer.stop()
    observer.join()

if __name__ == "__main__":
    main()

2. 部署与优化建议

部署方式​:

  1. Windows系统:打包为exe后台运行
    pyinstaller --onefile --windowed file_monitor.py
  2. Linux系统:配置为systemd服务
    sudo nano /etc/systemd/system/filemon.service

性能优化​:

  • 添加文件过滤:只监控特定类型文件
    if not file_path.endswith(('.pdf', '.docx')):
        return
  • 设置延迟处理:避免短时间重复触发
    last_trigger = 0
    def on_created(self, event):
        if time.time() - last_trigger < 5:  # 5秒内不重复处理
            return
        last_trigger = time.time()

五、企业级增强方案

安全增强实现部分源码

def check_virus(file_path):
    """简单的文件安全检查"""
    blacklist = ['.exe', '.bat', '.vbs']
    if Path(file_path).suffix.lower() in blacklist:
        wechat_notify("安全警报", f"发现可疑文件: {file_path}")
        quarantine_file(file_path)  # 隔离可疑文件

如需以下功能可私信沟通定制

  • 文件内容关键词扫描(合同/发票自动识别)
  • 操作审计日志(满足ISO27001要求)
  • AD域账号集成(自动识别操作用户)

下期预告​:
《Python+Redis实现分布式文件监控集群》- 百万级文件监控方案

您可能感兴趣的与本文相关的镜像

Python3.9

Python3.9

Conda
Python

Python 是一种高级、解释型、通用的编程语言,以其简洁易读的语法而闻名,适用于广泛的应用,包括Web开发、数据分析、人工智能和自动化脚本

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值