
本文介绍使用python的os.walk()遍历多层子目录,自动将每个operator文件夹下的pdf文件重命名为“operator0.pdf”“operator1.pdf”等格式,无需手动切换路径,安全高效地完成大规模文件批量重命名。
在实际数据处理中,我们常遇到类似 C:\State\County\Operator\file.pdf 这样的嵌套目录结构,需对每个 Operator 子文件夹内的 PDF 文件统一重命名(如 Operator0.pdf, Operator1.pdf…),而原始脚本仅适用于当前工作目录,每次切换文件夹都要手动修改路径,效率低下且易出错。
借助 Python 内置的 os.walk(),我们可以自上而下遍历整个目录树,精准定位每一级 Operator 文件夹,并在其内部独立编号重命名——关键在于:每个子目录内的计数器应独立重置,而非全局累加。以下是优化后的完整实现:
import os
root_dir = r"C:\State\County" # ⚠️ 注意:使用原始字符串避免转义问题
for dirpath, dirnames, filenames in os.walk(root_dir):
# 可选:仅处理名为 "Operator" 的文件夹(增强准确性)
# if os.path.basename(dirpath).lower() == "operator":
# 过滤出PDF文件并按顺序重命名
pdf_files = [f for f in filenames if f.lower().endswith('.pdf')]
for count, f in enumerate(pdf_files):
old_path = os.path.join(dirpath, f)
_, ext = os.path.splitext(f)
new_name = f"Operator{count}{ext}"
new_path = os.path.join(dirpath, new_name)
# 安全检查:跳过已存在同名文件,防止覆盖
if os.path.exists(new_path) and old_path != new_path:
print(f"⚠️ 跳过重命名:{old_path} → {new_path}(目标文件已存在)")
continue
try:
os.rename(old_path, new_path)
print(f"✅ 已重命名:{old_path} → {new_path}")
except PermissionError:
print(f"❌ 权限不足,无法重命名:{old_path}")
except Exception as e:
print(f"❌ 重命名失败 {old_path}:{e}")? 关键说明与最佳实践:
- ✅ 独立计数:enumerate(pdf_files) 在每个 dirpath 内重新开始计数,确保每个 Operator 文件夹均生成 Operator0.pdf, Operator1.pdf…
- ✅ 大小写兼容:f.lower().endswith('.pdf') 兼容 .PDF、.Pdf 等变体;
- ✅ 路径安全:使用 os.path.join() 拼接路径,适配 Windows/macOS/Linux;
- ✅ 防误覆盖:显式检查目标文件是否存在,避免意外覆盖;
- ✅ 异常防护:捕获 PermissionError 等常见异常,并输出清晰提示;
- ✅ 可扩展性:如需按 County 或 State 命名(如 CountyA_Operator0.pdf),可提取 os.path.dirname(dirpath) 中的上级目录名动态构造前缀。
? 运行前务必:
- 将 root_dir 替换为你的实际根路径(如 r"D:\Data");
- 先在测试副本目录中运行,确认逻辑无误;
- 如需保留原文件名线索(如 Operator0_originalname.pdf),可将 f_name 改为 os.path.splitext(f)[0] 并拼入新名。
此方案彻底摆脱了手动切换目录的繁琐操作,兼具鲁棒性与可维护性,是处理多层级文档归档任务的理想自动化方案。










