import os import openpyxl # Excel文件路径和图片文件所在文件夹路径 excel_file_path = 'C:\\Users\\Desktop\\pinyin_no_space.xlsx' img_folder_path = 'C:\\Users\\Desktop\\图片数据' # 加载Excel文件 wb = openpyxl.load_workbook(excel_file_path) sheet = wb.active # 创建一个字典来存储旧文件名到新文件名的映射 rename_map = {} for row in sheet.iter_rows(min_row=2, values_only=True): old_name = row[0] # 假设第一列是旧文件名 new_name = row[1] # 假设第二列是新文件名 rename_map[old_name] = new_name # 遍历图片文件夹中的所有文件 for filename in os.listdir(img_folder_path): # 检查文件是否是图片文件(这里只是示例,你可以根据需要添加更多扩展名) if any(filename.lower().endswith(ext) for ext in ['.jpg', '.jpeg', '.png', '.gif']): # 去除文件扩展名以匹配Excel中的名字 base_name, ext = os.path.splitext(filename) # 检查是否在映射字典中找到了旧文件名 if base_name in rename_map: new_filename = f"{rename_map[base_name]}{ext}" # 加上原文件的扩展名 old_file_path = os.path.join(img_folder_path, filename) new_file_path = os.path.join(img_folder_path, new_filename) # 重命名文件 os.rename(old_file_path, new_file_path) print(f"Renamed '{filename}' to '{new_filename}'") else: print(f"No mapping found for '{filename}' (base name: '{base_name}')") # 注意:如果Excel中的旧文件名与文件夹中的文件名不完全匹配(包括大小写和空格等), # 则重命名操作将不会执行。确保Excel中的文件名与文件夹中的文件名完全一致(或至少在你的匹配逻辑中是一致的)。