python批量处理应用

python之批量修改文件名


前言

当我们从网站爬取若干张图片,或需要将一些txt、excel、jpg等大批量的文件修改为有规律的名称,方便整理。

一、python批量修改文件名

提示:待修改的文件夹下只能包含需要修改的文件,然后更改源码里面的路径即可。

代码如下(示例):

#批量修改文件名
#批量修改图片文件名
import os
import re
import sys
def renameall():
	fileList = os.listdir(r"E:\py\python3.7\test\test17")		#待修改文件夹
	print("修改前:"+str(fileList))		#输出文件夹中包含的文件
	currentpath = os.getcwd()		#得到进程当前工作目录
	os.chdir(r"E:\py\python3.7\test\test17")		#将当前工作目录修改为待修改文件夹的位置
	num=1		#名称变量
	for fileName in fileList:		#遍历文件夹中所有文件
		pat=".+\.(jpg|png|gif|py|txt)"		#匹配文件名正则表达式
		pattern = re.findall(pat,fileName)		#进行匹配
		os.rename(fileName,(str(num)+'.'+pattern[0]))		#文件重新命名
		num = num+1		#改变编号,继续下一项
	print("---------------------------------------------------")
	os.chdir(currentpath)		#改回程序运行前的工作目录
	sys.stdin.flush()		#刷新
	print("修改后:"+str(os.listdir(r"E:\py\python3.7\test\test17")))		#输出修改后文件夹中包含的文件
renameall()

二、python批量修改文件名(按顺序)

使用os.listdir出现乱序,即修改文件名的时候不按照文件排列的顺序,例如os.listdir排列的顺序是按照例如:1,10,11,2,20,21…的顺序,想得到的正常顺序:1,2,3,4,5…需进行排序(参考自https://blog.csdn.net/weixin_42575079)

代码如下(示例):

import os


path=r'E:\py\python3.7\test\test19\excel'
fileList=os.listdir(path)
#get_key是sotred函数用来比较的元素,该处用lambda表达式替代函数。
get_key = lambda i : int(i.split('.')[0])
new_sort = sorted(fileList, key=get_key)
#print(fileList, '\n', new_sort)
n = 0

for i in fileList:
    # 设置旧文件名(就是路径+文件名)
    oldname = path + os.sep + new_sort[n]  # os.sep添加系统分隔符
    # 设置新文件名
    newname = path + os.sep + 'p' + str(n + 1)+'.csv'
    os.rename(oldname, newname)  # 用os模块中的rename方法对文件改名
    print(oldname, '======>', newname)
    n += 1

三、python批量修改文件名(删除指定字符)

1、批量删除指定字符段"-汇总数据-20211123"
在这里插入图片描述
在这里插入图片描述

代码如下(示例):

import os
import re
import time
 
 
"""对指定目录下的所有文件进行有选择的修改名称"""
def ReFileName(dirPath,pattern):
    """
    :param dirPath: 文件夹路径
    :param pattern: 正则匹配模式
    :return:
    """
    # 对目录下的文件进行遍历
    for file in os.listdir(dirPath):
        # 判断是否是文件
        if os.path.isfile(os.path.join(dirPath, file)) == True:
            # 用正则匹配,去掉不需要的词
            newName = re.sub(pattern, "", file)
            # 设置新文件名
            newFilename = file.replace(file, newName)
            # 重命名
            os.rename(os.path.join(dirPath, file), os.path.join(dirPath, newFilename))
    print("文件名已统一修改成功")
  
 
if __name__ == '__main__':
    timeStart = time.time()
    dirPath = r"E:\py\python3.7\test\test19\excel1"	
#   pattern = re.compile(r'\[{1}(.+)]\.')
    pattern = re.compile(r'\-汇{1}(.+)3')
    ReFileName(dirPath,pattern)
    timeEnd = time.time()
    print("程序走了%d秒"%(timeEnd-timeStart))

四、python批量修改文件名(按excel给定格式)

1、批量按照excel姓名和学号匹配修改图片名称;
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

代码如下(示例):

import os
import xlwings as wx

def listdir(path, list_name):  #传入存储的list
    for file in os.listdir(path):
        # 排除临时的文件
        if '~$' in file:
            continue

        # 取得照片清单
        if ".jpg" in file:
            file_path = os.path.join(path,file)
            list_name.append(file_path)

        # 取得excel文件
        if ".xlsx" in file:
            index_file = os.path.join(path,file)
            print("数据源文件-->"+index_file)

    print(list_name)
    return index_file

def getinfo(new_name,index_file):          # 获取人员姓名和编号
    app = wx.App(visible=False, add_book=False) # 不打开baiexcel
    print("读取人员信息--->"+index_file)
    wb = app.books.open(index_file)
    sheet = wb.sheets[0]

    nrows    = sheet.used_range.last_cell.row       #获取最大行数
    ncolumns = sheet.used_range.last_cell.column    #获取最大列数

    # 查找姓名和编号的列
    file_name = ""
    empl_name = ""
    empl_numb = ""
    ename_col = 0
    enumb_col = 0

    print("最大列数--->"+str(ncolumns))

    for col in range(1, ncolumns+1):
        if sheet.range((1,col)).value == "姓名":
            ename_col = col
            print("姓名的列--->"+str(col))
        
        if sheet.range((1,col)).value == "学号":
            enumb_col = col
            print("员工号的列--->"+str(col))

    # 取行中的姓名和编号
    for row in range(2,nrows+1):
        empl_name = str(sheet.range((row,ename_col)).value)
        empl_numb = str(sheet.range((row,enumb_col)).value)
        file_name = (empl_name + empl_numb).split('.')[0]       # 新的名字
        print(file_name)
        new_name.append(file_name)

    print(new_name)

    wb.close()
    app.quit()

def change_name(file_path,new_name,list_name):
    # 逐个处理照片
    for filename in list_name:
        print("旧文件名"+filename)
        old_name = (os.path.basename(filename)).split('.')[0]
        # 查找新名字清单中是否有此姓名
        for nfile in new_name:
            if old_name in nfile:
                nfname = file_path+os.sep+nfile+".jpg"
                print("新文件名"+nfname)
                os.rename(filename,nfname)
                break

def main():
    file_path = input('输入文件夹路径:') 
    try:
        #读取文件夹下的所有文件
        List_files=[]
        index_file = listdir(file_path,List_files)

        # 读取员工姓名和员工号,组成新的文件名
        new_name=[]
        getinfo(new_name,index_file)

        # 修改文件名字
        change_name(file_path,new_name,List_files)

    except Exception as  e:
        # 打印异常信息
        print(e)


if __name__ == '__main__':
    main()

总结

分享:
写作,是心灵的事业,是没有上下班界限的,不是只有正襟危坐才算写作。写作是一件令人遗憾的事业一—越追求完美,所感知的遗漏和瑕疵似乎也越多;写作的时间越长,惶惑、焦虑及不确定性似乎也与日俱增。

  • 8
    点赞
  • 67
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

若竹之心

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值