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 )批量修改指定路径下的文件名
张小明
前端开发工程师
AI训练场景下的革命性存储解决方案:突破性分布式系统架构全解析
在当今AI模型规模指数级增长的时代,传统存储系统已成为制约训练效率的瓶颈。本文将为您深入剖析一种专为AI训练场景设计的突破性存储解决方案,揭示其如何通过全新范式解决大规模分布式计算的存储挑战。🚀 【免费下载链接】3FS A high-perfor…
RuoYi-Cloud-Plus SSE实时推送:企业级消息通信终极指南
RuoYi-Cloud-Plus SSE实时推送:企业级消息通信终极指南 【免费下载链接】RuoYi-Cloud-Plus 微服务管理系统 重写RuoYi-Cloud所有功能 整合 SpringCloudAlibaba、Dubbo3.0、Sa-Token、Mybatis-Plus、MQ、Warm-Flow工作流、ES、Docker 全方位升级 定期同步 项目地址…
让智能家居“听懂人话”:我用4B模型+万条数据,教会了它理解复杂指令
在智能家居场景中,我们经常遇到这样的尴尬: 你说:“把灯打开。” —— 它可以执行。 你说:“如果检测到漏水,就把水阀关了并发个通知。” —— 它可能听不懂了。 你说:“有点冷,把空调调高一点。…
ShawzinBot:Warframe音乐创作的全新革命
ShawzinBot:Warframe音乐创作的全新革命 【免费下载链接】ShawzinBot Convert a MIDI input to a series of key presses for the Shawzin 项目地址: https://gitcode.com/gh_mirrors/sh/ShawzinBot 还在为Warframe中复杂的Shawzin演奏而烦恼吗?想…
超简单破解在市面上的流水灯,学会后你也可以在家里制作
这里写自定义目录标题知识准备材料准备硬件连接代码实现代码知识点常见错误拓展改进实际应用实践心得知识准备 数组基础:数组是存储多个相同类型数据的集合,通过索引访问元素,索引从0开始LED工作原理:发光二极管需串联限流电阻&a…
用Python调用EmotiVoice:语音合成脚本编写示例
用Python调用EmotiVoice:语音合成脚本编写示例 在内容创作日益自动化的今天,我们不再满足于“能说话”的AI语音——我们需要的是会表达、有性格、像真人的声音。无论是为短视频配上情绪饱满的旁白,还是让游戏角色说出带怒意或调侃语气的台词&…