python怎么批量修改文件名字,python批量修改文件后缀名
最近有个同事有批量修改文件名的需求。本文主要介绍了python批量修改文件名的三种方法,并通过示例代码进行了详细介绍。有需要的可以参考一下。
00-1010前言一、python批量修改文件名二。python批量修改文件名(按顺序)III。python批量修改文件名(删除指定字符)摘要
目录
当我们从网站上抓取了多张图片,或者需要将txt、excel、jpg等一些文件修改成常规名称的时候,方便整理。
提示:以下是本文的主要内容,以下案例可供参考。
前言
提示:要修改的文件夹只能包含要修改的文件,然后在源代码中更改路径。
1.源代码
代码如下(示例):
#批量修改文件名
#批量修改图像文件名
导入操作系统
进口re
导入系统
def renameall():
file=OS . listdir(r e : \ py \ python 3.7 \ test \ test17 )#要修改的文件夹
print( before modification: str(file list))#输出文件夹中包含的文件
Currentpath=os.getcwd()#获取进程的当前工作目录
OS . chdir(r e : \ py \ python 3.7 \ test \ test 17 )#将当前工作目录修改到要修改的文件夹的位置。
Num=1#名称变量
对于文件列表中的文件名3360 #遍历文件夹中的所有文件
Pat=。\.(jpgpnggifpytxt)#正则表达式匹配文件名
Pattern=re.findall (pat,filename) #匹配
OS.rename(文件名,(字符串(数字).模式[0])) #文件重命名
Num=num 1#更改数字并移到下一项。
打印(-)
Os.chdir(currentpath)#在程序运行前变回工作目录。
Sys.stdin.flush()#刷新
print( after modification: str(OS . listdir(r e : \ py \ python 3.7 \ test \ test17 ))#输出修改后的文件夹中包含的文件
雷纳米尔()
一、python批量修改文件名
1.源代码
提示:使用os.listdir时有乱序,即修改文件名时没有按照文件的顺序。例如,os.listdir的顺序是例如1、10、11、2、20、21…的顺序。想要的正常顺序:1,2,3,4,5…需要排序(参考https://www . jb51 . net/article/247381 . htm)。
代码如下(示例):
导入操作系统
#设置文件路径
path=r e : \ py \ python 3.7 \ test \ test19 \ excel
#获取该目录中的所有文件,并将它们存储在列表中。
fileList=os.listdir(路径)
#get_key是sotred function用来比较的元素,这里用lambda表达式代替function。
get _ key=lambda I : int(I . split( . )[0])
new_sort=sorted(fileList,key=get_key)
#print(文件列表, \n ,new_sort)
n=0
对于文件列表:中的I
#设置旧文件名(即路径文件名)
old name=path OS . sep new _ sort[n]# OS . sep添加系统分隔符
#设置新的文件名
newname=path os.sep p str(n 1)。csv
Os.rename(oldname,newname) #使用Os模块中的rename方法重命名文件。
print(旧名称,=====,新名称)
n=1
二、python批量修改文件名(按顺序)
1.指定字符域的批量删除-汇总数据-202112
3"
2、批量删除指定字符段"[ * 图灵程序设计丛书 * ]."
(参考自https://blog.csdn.net/qiukui111)
1.源码
代码如下(示例):
import osimport 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 osimport 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批量修改文件名内容请搜索盛行IT软件开发工作室以前的文章或继续浏览下面的相关文章希望大家以后多多支持盛行IT软件开发工作室!
郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。