当前位置: 首页 > news >正文

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

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 )
http://www.jsqmd.com/news/105680/

相关文章:

  • 用少量音频样本克隆音色?EmotiVoice轻松实现
  • ctfshow web入门web160
  • 5分钟快速上手DWMBlurGlass:让你的Windows界面焕然一新
  • word宏批量插入.csv格式的附件
  • ChatTTS音色定制终极指南:从零打造专属语音体验
  • 3步搞定李跳跳自定义规则:彻底告别手机弹窗的终极清净方案
  • Python+Vue的图书馆借阅归还管理系统_ Pycharm django flask
  • AndroidGen实战指南:突破移动AI代理评估瓶颈的深度解析
  • Sist2搜索工具:快速构建个人知识库的终极指南
  • Tiled碰撞蒙版终极指南:5分钟掌握游戏物理边界设计
  • 17、网络攻击与Apache服务器安全解析
  • 5个理由选择gsplat.js:终极JavaScript高斯点投射库
  • 远程桌面连接报错0x80004005?网络配置+防火墙设置的全面排查方案(适用于 Windows 10/11)
  • 视觉语言导航实战:让AI听懂你的每一个指令
  • FunASR热词功能实战指南:5分钟让语音识别更懂你的专业术语
  • EmotiVoice语音合成系统灾备方案设计与演练建议
  • Flink状态监控实战:从数据倾斜到内存优化的完整解决路径
  • 项目管理工具盘点与测评:覆盖流程管理、进度协同的工具选型指南
  • Headless Chrome Crawler终极指南:从零开始构建分布式爬虫系统
  • Quantum ESPRESSO终极指南:免费掌握电子结构计算的快速入门方法
  • RQ任务日志管理:从混乱到有序的实战指南
  • 一个由代码规范性导致的bug:结构体没有memset导致的Segmentation fault (core dumped)
  • Emby媒体服务器界面定制化方案深度解析
  • 强力教程:3步掌握X-AnyLabeling中GeCO模型的目标计数技术
  • 基于树莓派nmcli详细使用,其它Linux应该差不多的
  • Cap开源录屏工具终极指南:5步快速上手专业录制
  • 2025最新国内电子签名排行:国内电子签名软件哪家强? - 博客万
  • 基于Springboot实现的校园订餐管理系统小程序设计与实现【源码+文档】
  • SystemInformer语言定制:从英文界面到多语言自由切换
  • 基于SSM实现的小说阅读小程序设计与实现【源码+文档】