Sublime如何启用保存时自动备份到指定目录?(版本冗余)

1次阅读

sublime text原生无保存时自动备份到指定目录功能,仅生成同目录.sublime-swp临时文件;需通过autosave插件配合自定义auto_backup.py脚本实现,使用shutil.copy2保留时间戳并注意路径格式、权限及并发冲突。

Sublime如何启用保存时自动备份到指定目录?(版本冗余)

sublime text 的自动备份机制本质是临时文件,不是版本管理

Sublime Text 本身不提供“保存时复制一份到指定目录”的功能,它只会在编辑时生成 .sublime-swp 临时文件(位于原文件同目录),用于崩溃恢复。所谓“自动备份到指定目录”,其实是靠第三方插件或外部脚本实现的,原生不支持路径重定向。

用 AutoSave 插件 + 自定义 on_post_save 事件实现备份

推荐安装 AutoSave 插件(Package Control 可搜),但它默认只触发保存,不负责拷贝。真正起作用的是在 Preferences → Browse Packages → User 下新建 auto_backup.py 文件,写入监听逻辑:

import os import shutil import sublime import sublime_plugin <p>class AutoBackupListener(sublime_plugin.EventListener): def on_post_save(self, view): file_path = view.file_name() if not file_path or not os.path.isfile(file_path): return backup_dir = "/path/to/your/backup"  # ← 改成你的目标目录 if not os.path.exists(backup_dir): os.makedirs(backup_dir) filename = os.path.basename(file_path) backup_path = os.path.join(backup_dir, filename) try: shutil.copy2(file_path, backup_path)  # 保留时间戳 except OSError: pass
  • shutil.copy2copy 更稳妥,能保留修改时间
  • 路径必须用正斜杠 / 或双反斜杠 ,单反斜杠会报错
  • windows 用户注意:路径开头写成 C:backup,别漏转义
  • 如果文件名含 Unicode 字符(如中文),shutil.copy2 在旧版 Sublime(subprocess 调用系统 copy/cp

备份命名冲突:不加时间戳就覆盖,加了又难检索

上面脚本每次保存都覆盖同名文件,适合“最新版快照”场景;但如果你要留历史版本,得手动加时间戳。简单改法是在 backup_path 构造时插入时间:

import time timestamp = time.strftime("%Y%m%d_%H%M%S") backup_path = os.path.join(backup_dir, f"{filename}.{timestamp}")
  • 时间戳格式越短越好,避免路径超长(Windows 有 260 字符限制)
  • 不要用 :* 等非法字符,strftime 里用 %H%M%S 不用 %H:%M:%S
  • 频繁保存小文件会产生大量备份,建议搭配定时清理脚本(比如每天删 7 天前的)

性能与权限:大文件、网络盘、只读文件容易静默失败

这个监听逻辑跑在 Sublime 主线程,如果备份目录在慢速网络盘(如 SMB/NFS)、或目标磁盘空间不足、或原文件被其他进程锁住,on_post_save 会卡顿甚至导致 Sublime 假死——而且不会弹错误提示,只会默默跳过。

  • 大文件(>10MB)建议加大小判断:if os.path.getsize(file_path)
  • 备份目录务必有写权限,macos 上挂载的 APFS 卷有时对硬链接敏感,优先用 copy2 而非 os.link
  • 只读文件(如 chmod 444)无法备份,但 Sublime 仍允许编辑并保存(会先解除只读),此时备份逻辑可能因权限检查滞后而失败

真正麻烦的是“备份成功但内容不对”:比如你用 git 管理项目,又同时开了 ide 同步,备份时机和文件锁竞争会导致拷贝到一半的中间状态。这种事没法靠插件兜底,得靠流程约束——要么关掉其他工具的实时同步,要么把备份目录排除在 Git 和同步软件之外。

text=ZqhQzanResources