当前位置: 首页 > 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.rkmt.cn/news/116602.html

相关文章:

  • ctfshow web入门web160
  • Boltz生物分子交互模型安装配置完全指南
  • AndroidGen实战指南:突破移动AI代理评估瓶颈的深度解析
  • FunASR热词功能实战指南:5分钟让语音识别更懂你的专业术语
  • EmotiVoice语音合成系统灾备方案设计与演练建议
  • Quantum ESPRESSO终极指南:免费掌握电子结构计算的快速入门方法
  • Emby媒体服务器界面定制化方案深度解析
  • 强力教程:3步掌握X-AnyLabeling中GeCO模型的目标计数技术
  • Cap开源录屏工具终极指南:5步快速上手专业录制
  • 基于Springboot实现的校园订餐管理系统小程序设计与实现【源码+文档】
  • 基于SSM实现的小说阅读小程序设计与实现【源码+文档】
  • 为什么你应该选择FastExcel:5个让Excel处理效率翻倍的理由
  • 手把手教你用SeedVR2实现本地化视频修复与增强
  • Vue3+Element Plus后台管理系统实战应用开发指南
  • ForensicsTool取证工具:从零开始的完整安装配置手册
  • GEO 运营商哪家好?2025 年综合实力排名榜:全场景适配力 TOP5 揭晓
  • 【LeetCode热题100(74/100)】跳跃游戏
  • AI技术如何通过SSE框架提升开发效率与质量
  • 解锁AMD 780M全部潜能:ROCm优化库实战指南
  • 5步实现智能机器人云服务集成:从零到自动化的完整指南
  • 基于Spring Boot宠物医院管理系统设计与实现(完整源码+万字论文+精品PPT)
  • 2025年主流获客系统推荐:十大服务商选型指南与深度测评
  • XJTU-thesis:西安交通大学学位论文LaTeX模板完全使用手册
  • 5分钟搞定Lottie-web动画集成:让前端开发效率提升300%
  • EmotiVoice支持RESTful API吗?集成方式详解
  • ESP32智能手表:开源硬件与可定制软件的完美融合
  • 如何解决 Kotlin/Native 在 Windows 下 main 函数的 args 乱码?
  • EmotiVoice是否支持增量更新?模型热升级可行性探讨
  • 32、Linux系统基础操作与管理知识解析
  • Pyxel编辑器入门指南:零基础掌握像素艺术与游戏创作