批量图片重命名python版

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中的文件名与文件夹中的文件名完全一致(或至少在你的匹配逻辑中是一致的)。
  • 24
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值