尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

批量修改指定路径下的文件名

批量修改指定路径下的文件名
📅 发布时间:2026/6/19 8:10:06
import os import shutil def batch_rename_csv(folder_path, replace_old='NMOS', replace_new='NMOS', case_insensitive=True, recursive=False): """ 批量修改指定文件夹下CSV文件的名称,支持大小写不敏感、递归处理子文件夹、管理员权限兼容 :param folder_path: 目标文件夹路径(绝对路径/相对路径) :param replace_old: 要替换的旧字符串(默认NMOS) :param replace_new: 替换后的新字符串(默认NMOS) :param case_insensitive: 是否大小写不敏感(默认True) :param recursive: 是否递归处理子文件夹(默认False) """ # 检查文件夹是否存在 if not os.path.isdir(folder_path): print(f"错误:文件夹 '{folder_path}' 不存在!") return # 遍历文件夹:recursive=True时递归处理子文件夹 for root, dirs, files in os.walk(folder_path): for file_name in files: # 筛选.csv文件 if not file_name.endswith('.csv'): continue # 处理大小写不敏感的匹配 file_name_lower = file_name.lower() old_str_lower = replace_old.lower() if case_insensitive: if old_str_lower not in file_name_lower: continue # 替换所有大小写形式的旧字符串(如NMOS/NMOS/NMOS都替换为NMOS) new_file_name = file_name # 先按小写匹配替换,确保全部替换 import re new_file_name = re.sub(re.escape(replace_old), replace_new, new_file_name, flags=re.IGNORECASE) else: if replace_old not in file_name: continue new_file_name = file_name.replace(replace_old, replace_new) # 构造旧文件和新文件的完整路径 old_file_path = os.path.join(root, file_name) new_file_path = os.path.join(root, new_file_name) # 跳过自身(文件名未变化的情况) if old_file_path == new_file_path: continue # 处理重名问题:可选覆盖/跳过/添加后缀 if os.path.exists(new_file_path): # 方案1:跳过(原逻辑) # print(f"警告:新文件名 '{new_file_name}' 已存在,跳过该文件!") # continue # 方案2:强制覆盖(谨慎使用,会替换原有文件) # os.remove(new_file_path) # 删除原有文件 # os.rename(old_file_path, new_file_path) # print(f"强制覆盖:{file_name} → {new_file_name}") # 方案3:添加数字后缀(推荐,避免覆盖) count = 1 while os.path.exists(new_file_path): name, ext = os.path.splitext(new_file_name) new_file_name = f"{name}_{count}{ext}" new_file_path = os.path.join(root, new_file_name) count += 1 os.rename(old_file_path, new_file_path) print(f"重名处理后重命名:{file_name} → {new_file_name}") else: try: # 重命名文件(兼容不同权限) os.rename(old_file_path, new_file_path) print(f"成功:{file_name} → {new_file_name}") except PermissionError: # 权限不足时,尝试用shutil移动(部分场景可绕过权限) try: shutil.move(old_file_path, new_file_path) print(f"管理员权限不足,使用shutil成功:{file_name} → {new_file_name}") except Exception as e: print(f"失败:{file_name} → 权限不足或文件被占用,错误:{e}") except Exception as e: print(f"失败:{file_name} → 未知错误,错误:{e}") # 若不递归,只处理当前文件夹后退出 if not recursive: break print("批量重命名操作完成!") # -------------------------- 配置区 -------------------------- # 替换为你的目标文件夹路径 target_folder = r"C:\Users\a\Desktop\NMOS" # 要替换的旧字符串和新字符串(可根据需求修改,如noms→NMOS) replace_old_str = "nmos" replace_new_str = "NMOS" # 是否递归处理子文件夹(True/False) recursive_process = False # ------------------------------------------------------------- if __name__ == "__main__": batch_rename_csv( folder_path=target_folder, replace_old=replace_old_str, replace_new=replace_new_str, recursive=recursive_process )

相关新闻

  • ctfshow web入门web160
  • Boltz生物分子交互模型安装配置完全指南
  • AndroidGen实战指南:突破移动AI代理评估瓶颈的深度解析

最新新闻

  • 深孔钻头选购,如何选择永昌工具这样的好品牌 - 工业品网
  • 2026年免费快速:PPT转PDF并压缩全攻略(小程序+公众号) - 时时资讯
  • LLM与RNN混合架构在代码理解中的应用与优化
  • 河北福亚斯保温建材口碑怎么样?深度评测与推荐 - mypinpai
  • 2026年好用的PTFE管道品牌,推荐哪家? - mypinpai
  • 邢台黄金回收门店实地探访全记录 - 余生黄金回收

日新闻

  • 5分钟掌握Python进化算法:Geatpy高性能优化工具完全指南
  • Microchip 24AA044 EEPROM选型与应用全指南:从参数解析到实战编程
  • 华为的鸿蒙到底有多牛?为什么称作遥遥领先?

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号