欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

基于python脚本的批量自动更改文件名

程序员文章站 2022-03-02 14:16:55
...

基于python脚本的批量自动更改文件名

   作为一名大学班长,经常面临收作业的问题。为了电子档作业方便清点人数,也为了整洁美观,老师常常都会规定作业的命名格式。
例如: “班级+学号+姓名_作业一”这样的格式。但是同学们交上来的作业名往往是千奇百怪。
   有这样的:“通信170101+张三+作业一”
   也有这样的:“1403170101+张三_作业一”
   甚至还有这样的:“通信170101张三作业一”
明明正确的命名应该是:“通信170101张三_作业一”。但就是这样一个简简单单的问题,总有很多人做不好。搞得我在收作业的时候就得一个一个重命名,弄得我脑壳大。

于是我就用python写了个小程序,把那些乱七八糟的命名都自动修正好。

话不多说,直接看程序。不过得先介绍一下准备工作。

首先我在桌面有个全班名单的excel文件基于python脚本的批量自动更改文件名
打开之后是这样的
基于python脚本的批量自动更改文件名
然后你把要改名的文件全都放到另一个文件夹里就行

import os
import pandas as pd 
import re 

#这个函数是把每个人的学号和名字从excel文件里提取出来,以便下面改名
def excel_to_list(name_list):  
    df = pd.read_excel(name_list, usecols=[1,2],names=None) 
    #读取项目名称列
    #usecols=[1,2]表明取第二列和第三列,也就是学号和名字。
    #names=None表明不要列名
    df_li = df.values.tolist()
    #print(df_li)
    return df_li  #return的就是学号和名字


if __name__ == '__main__':
    name_list = "C:\\Users\\admin\\Desktop\\通信1701名单.xlsx"    #花名册地址
    path = 'C:\\Users\\admin\\Desktop\\新建文件夹\\'              #收作业地址
    work_name = '预习作业一'                                   #作业名字后缀    
    num_name_list = excel_to_list(name_list)
    count = 0; #数数一共有几份作业,看看齐了没


    for file in os.listdir(path): #遍历作业地址中每一份作业
        try:
            type = str(file).split('.')[1]  #判断是.doc文件还是.pdf文件等,保持格式不变
            type = '.' + type
            print("检测到此次作业类型为",type,"类型")
        except:
            type = None  #文件夹就没有格式后缀了      
            print("检测到此次作业类型为文件夹类型")  
        ini_taskname = str(file).split('.')[0] #把文件名中除了格式后缀的部分拿出来
        for nn in num_name_list:
            num = str(nn[0]) #学号
            na = nn[1] #名字
            if re.findall(r'1402',ini_taskname): #正则表达式,如果在学号中找到了‘1402’,说明是电子专业
                class_name = '电子'
            else:
                class_name = '通信'                                                         
            if re.findall(str(na)[0:3],ini_taskname): #只要文件名中写了本人姓名,就成功匹配到他的名字和学号。
                count = count+1;
                if type is  None: #对所有文件夹改名
                    os.rename(os.path.join(path,file),os.path.join(path,class_name+str(num[-6:])+str(na)+'_'+work_name))
                else: #对所有非文件夹文件改名
                    os.rename(os.path.join(path,file),os.path.join(path,class_name+str(num[-6:])+str(na)+'_'+work_name+type))
					#新的文件夹名字为“作业地址+专业名+班级学号(num[-6:0]是班级+学号的意思)+名字+下划线+文件格式”
    print("本次共计处理",count,"个文件") #看看作业收起了没

思来想去没有什么好办法能把每个人的作业匹配到他自己,只有用正则表达式匹配姓名了。不会有人交作业不写自己的名字吧?

那建议退学

总的来说,这是个很好用的脚本。我前两年都是很笨的手动改文件名,浪费了不少时间,希望这个小代码能帮助到各位要经常收文件的朋友。

如果觉得还不错,建议赞一下,下次给大家分享别的有用的东西