python批量修改文件名的三种方法实例

目录
  • 前言
  • 一、python批量修改文件名
  • 二、python批量修改文件名(按顺序)
  • 三、python批量修改文件名(删除指定字符)
  • 总结

前言

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

提示:以下是本篇文章正文内容,下面案例可供参考

一、python批量修改文件名

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

1.源码

代码如下(示例):

#批量修改文件名
#批量修改图片文件名
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批量修改文件名(按顺序)

1.源码

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

代码如下(示例):

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"

2、批量删除指定字符段"[ * 图灵程序设计丛书 * ]."

(参考自https://blog.csdn.net/qiukui111)

1.源码

代码如下(示例):

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姓名和学号匹配修改图片名称;

1.源码

代码如下(示例):

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()

总结

到此这篇关于python批量修改文件名的三种方法的文章就介绍到这了,更多相关python批量修改文件名内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 利用Python对文件夹下图片数据进行批量改名的代码实例

    1. 前言 我们最近在做一个使用flask 模拟 instagram 的图片分享网站, 需要一些基本的图片数据, 我们这里采用的是本地提供, 但是,使用爬虫从网上爬下来的图片,名字都是乱七八糟的,不利于编程,这里就需要对他们进行批量改名操作. 2. 基本思路 使用python 的os 模块,对文件夹进行遍历(listdir), 同时使用rename 进行改名操作 3. 实现效果 4. 实现代码 代码非常简单 # -*- coding:utf8 -*- import os class BatchR

  • python批量修改文件夹及其子文件夹下的文件内容

    前言:前几天我看一位同学要修改很多文件中的数据,该文件数据很规律,一行只有三个数,需要将每行最后一个数字改为负数,但文件有上千个,分布在每个文件夹下面以及它的多级子文件夹下,看他用excel手动改数据改的很痛苦,我突然想到用Python访问和操作文件,修改文件内容都很方便,于是在对Python不熟悉的情况下花了大半天写了下面的程序. 大概思路:先获取文件夹下所有文件名存在列表中,然后循环遍历访问文件内容,修改后写入新文件,考虑到还有子文件夹,这里用了递归的方法访问子文件夹的文件,最后修改完再把原

  • python批量修改文件名的三种方法实例

    目录 前言 一.python批量修改文件名 二.python批量修改文件名(按顺序) 三.python批量修改文件名(删除指定字符) 总结 前言 当我们从网站爬取若干张图片,或需要将一些txt.excel.jpg等大批量的文件修改为有规律的名称,方便整理. 提示:以下是本篇文章正文内容,下面案例可供参考 一.python批量修改文件名 提示:待修改的文件夹下只能包含需要修改的文件,然后更改源码里面的路径即可. 1.源码 代码如下(示例): #批量修改文件名 #批量修改图片文件名 import o

  • BAT脚本批量修改文件名的两种方法

    目录 一,先进入想要修改文件名的文件夹中,使用命令: 1.以示例文档为例进行说明 2.双击1.bat来生成yuan.xls文件,如下图: 二.直接通过BAT脚本实现 通过BAT脚本批量修改文件名的办法有两种: 一,先进入想要修改文件名的文件夹中,使用命令: dir /b "*.后缀名" > yuan.xls 从生成含有所需文件名的xls文件(即Excel文件),然后在xls文件中通过 CONCATENATE("ren ",A2," ",B2

  • Python批量模糊匹配的3种方法实例

    目录 前言 使用编辑距离算法进行模糊匹配 使用fuzzywuzzy进行批量模糊匹配 fuzz模块 process模块 整体代码 使用Gensim进行批量模糊匹配 Gensim简介 使用词袋模型直接进行批量相似度匹配 使用TF-IDF主题向量变换后进行批量相似度匹配 同时获取最大的3个结果 完整代码 总结 前言 当然,基于排序的模糊匹配(类似于Excel的VLOOKUP函数的模糊匹配模式)也属于模糊匹配的范畴,但那种过于简单,不是本文讨论的范畴. 本文主要讨论的是以公司名称或地址为主的字符串的模糊

  • python运行脚本文件的三种方法实例

    目录 python脚本执行的3种方法: 方法一:交互模式直接执行语句 方法二:通过脚本输出 方法三:脚本中指定 python 路径,修改文件为可执行文件 总结 python脚本执行的3种方法: (找到自己能够使用的方法,能用的方法就是好方法) 方法一:交互模式直接执行语句 交互模式下直接编写执行 Python语句,不用再创建脚本文件 Windows下: 打开并进入命令提示符-------->输入python并回车-------->即可进入交互模式 Linux 下: 打开终端模拟器-------

  • MyBatis批量插入数据的三种方法实例

    目录 前言 准备工作 1.循环单次插入 2.MP 批量插入 ① 控制器实现 ② 业务逻辑层实现 ③ 数据持久层实现 MP 性能测试 MP 源码分析 3.原生批量插入 ① 业务逻辑层扩展 ② 数据持久层扩展 ③ 添加 UserMapper.xml 原生批量插入性能测试 缺点分析 解决方案 总结 前言 批量插入功能是我们日常工作中比较常见的业务功能之一,之前我也写过一篇关于<MyBatis Plus 批量数据插入功能,yyds!>的文章,但评论区的反馈不是很好,主要有两个问题:第一,对 MyBat

  • python批量下载图片的三种方法

    有三种方法,一是用微软提供的扩展库win32com来操作IE,二是用selenium的webdriver,三是用python自带的HTMLParser解析.win32com可以获得类似js里面的document对象,但貌似是只读的(文档都没找到).selenium则提供了Chrome,IE,FireFox等的支持,每种浏览器都有execute_script和find_element_by_xx方法,可以方便的执行js脚本(包括修改元素)和读取html里面的元素.不足是selenium只提供对py

  • 视频合并时使用python批量修改文件名的方法

    不知道大家有没有遇到这样的情况,比如视频合并时文件名没有按照正常顺序排列,像这样 可见,文件名排序是乱的.这个样子合并出来的视频一定也是乱的.所以得想办法把文件名修改一下,让软件读取出正确的顺序.闲话少说,上代码. """ 注意:一.文件名除去扩展名必须以 '_' + 数字 结尾.  二.convert.py 放在文件目录.  三.目录中不能有多余文件 主要算法: 根据最大数字的位数添加0 例如,如果最大数字为123,那么位数为3位,  1就要变成001.2变成002.23变

  • 使用python批量修改文件名的方法(视频合并时)

    不知道大家有没有遇到这样的情况,比如视频合并时文件名没有按照正常顺序排列,像这样 可见,文件名排序是乱的.这个样子合并出来的视频一定也是乱的.所以得想办法把文件名修改一下,让软件读取出正确的顺序.闲话少说,上代码. """ 注意:一.文件名除去扩展名必须以 '_' + 数字 结尾.  二.convert.py 放在文件目录.  三.目录中不能有多余文件 主要算法: 根据最大数字的位数添加0 例如,如果最大数字为123,那么位数为3位,  1就要变成001.2变成002.23变

  • Python批量修改文件名,文件再多也只要一秒

    目录 一.我为什么要写这篇 二.在原有的名字前中后批量加字 三.所有文件重新命名并添加序号 四.导入Excel数据批量修改为文件名 一.我为什么要写这篇 好兄弟们,妹子要少看,技能要多学,每天一个小技巧,撩妹手段少不了~ 昨天有人问我怎么批量修改文件名,然后我随便写了一种,他说我不nice,这我就忍不住了,反手就给他写了好几种,你们来看看,这个到底刑不刑. 很多兄弟在学习Python的时候因为不太明确学习方向,没有好的学习资料,遇到问题也没人解答,就很难受,甚至可能学着学着就放弃了,直接私我就行

  • Python操作配置文件ini的三种方法讲解

    python 操作配置文件ini的三种方法 方法一:crudini 命令 说明 crudini命令是Linux下的一个操作配置文件的命令工具 用法 crudini --set [--existing] config_file section [param] [value] # 修改配置文件内容 crudini --get [--format=sh|ini] config_file [section] [param] # 获取配置文件内容 crudini --del [--existing] co

随机推荐