python - 在 Python 中按特定格式重命名子文件夹中的文件
问题描述
我有一个包含很多子文件夹的文件夹。每个子文件夹都有不同类型的图像文件。我正在尝试按特定格式重命名这些文件。数据如下所示:
folder
\ sub1\file0.jpg
\ sub1\file1.jpg
\ sub1\file2.png
.
.
.
\ sub2\xxx.png
\ sub2\yyy.jpg
\ sub2\zzz.png
.
.
.
期望的输出:
folder
\ sub1\file-01.jpg
\ sub1\file-02.jpg
\ sub1\file-03.png
.
.
.
\ sub2\file-01.png
\ sub2\file-02.jpg
\ sub2\file-03.png
.
.
.
到目前为止,我已经尝试过以下代码,但没有成功。
import os
dir_name = "D:/folder"
for root, dirs, files in os.walk(dir_name, topdown=False):
for file in files:
file_name = os.path.splitext(file)[0]#file name no ext
extension = os.path.splitext(file)[1]
dir_name = os.path.basename(root)
os.rename(root+"/"+file, root+"/"+"file"+"s%"+extension)
解决方案
这是一种使用enumerate
.
演示:
import os
dir_name = "D:/folder"
for root, dirs, files in os.walk(dir_name, topdown=False):
for num, file in enumerate(files, 1): #enumerate to get number
src = os.path.join(root, file)
file_s = os.path.splitext(file)
dest = os.path.join(root, "{0}-{1}.{2}".format(file_s[0], str(num).rjust(2, "0"), file_s[1])) #Form destination file name
os.rename(src, dest) #Rename.
推荐阅读
- spring-cloud-stream - Spring Cloud Stream Binder
- excel - 从每个工作表中的单元格值填充列
- java - 休眠:org.hibernate.QueryException
- c# - 检索 N:N 关系 Dynamics CRM
- c# - 如何修改静态属性?
- python - del()与python中的del语句
- angular - 单元格未按照样式 Xlsx-Styles Angular 4 进行格式化
- entity-framework - Web api中实体框架中的批量更新
- c# - Api 控制器 post 方法返回 404 - 未找到
- excel - 带有 VLOOKUP 的嵌套 IF 语句