深度学习目标检测任务中常常需要大量的图片,这些图片一般来自网络爬虫或是自行批量下载,但下载下的图片常常在保存时被命名为长段英文数字混写,因此规律化命名下载的图片数据名称就显得尤为重要了,下面我演示在本人电脑上如何批量修改图片的操作。

1,提取图片原文件名至Excel表中

首先,crtl+a全选所有图片,并按住shift键,点击复制文件地址,再打开新建的excel表,点击A1单元格粘贴,再利用查找与替换功能去除复制的图片地址。相关操作如下:

批量修改图片名字 python 批量修改图片名字_python

批量修改图片名字 python 批量修改图片名字_python_02

批量修改图片名字 python 批量修改图片名字_python_03

2,设置想要修改的图片名称

这里为了简便,设置图片由1开始逐个加1编号,并于第二列中将改后的图片名称设置完毕,相关操作如下

批量修改图片名字 python 批量修改图片名字_文件名_04

3,在C列中输入更名公式

选中C列,在编辑栏中输入公式

\[="ren "&A1&" "&B1&"" \]

之后按回车键,并用鼠标移动到C1单元格右下角出现+字往下填充。

批量修改图片名字 python 批量修改图片名字_文件名_05

公式的含义是将A1列中名字重命名为B列名字

4,新建一个批处理文档

在与图片文件夹相同的目录下新建一个txt文档,复制Excel表格中的C列公式全列到txt文档中粘贴,保存并更改txt文档的后缀名为.bat,在保存后关闭并双击执行.bat文件,之后图片应被批量更改了

批量修改图片名字 python 批量修改图片名字_批量修改图片名字 python_06

注:若是新旧名称中包含空格字符会导致改名失败,若是需要更改包含空格字符的文件,需要加入双引号,如:ren "oldname.c" "newname.c"。

对于有空格的特殊情况,如下图操作,在第3步中加入在C列的第一个单元格打入英文的引号",在D列1格输入以下公式即可:

="ren "&C1&A1&C1&" "&C1&B1&C1

批量修改图片名字 python 批量修改图片名字_批量修改图片名字 python_07

5,利用python更改文件名字

代码如下,更改图片存放路径再用python运行即可,本人python版本3.7:

# -*- coding:utf8 -*-
 
import os
 
class BatchRename():
    '''
    批量重命名文件夹中的图片文件
    '''
    def __init__(self):
        #我的图片文件夹路径horse
        self.path = 'C:\\Users\\username\\Desktop\\ImageData\\Pascal_VOC\\JPEGImages'
 
    def rename(self):
        filelist = os.listdir(self.path)
        total_num = len(filelist)
        i = 1
        n = 6
        for item in filelist:
            if item.endswith('.jpg'):
                n = 6 - len(str(i))
                src = os.path.join(os.path.abspath(self.path), item)
                dst = os.path.join(os.path.abspath(self.path), str(0)*n + str(i) + '.jpg')
                try:
                    os.rename(src, dst)
                    print('converting %s to %s ...' % (src, dst))
                    i = i + 1
		    
                except:
                    continue
        print('total %d to rename & converted %d jpgs' % (total_num, i))
 
if __name__ == '__main__':
    demo = BatchRename()
    demo.rename()

批量修改图片名字 python 批量修改图片名字_python_08