背景需求
下载教程,手动输入编号,有一个编号错误,导致后面所有编号都错了。30实际是29,以此类推
怎样才能快速修改编号数字?
data:image/s3,"s3://crabby-images/f8d22/f8d22e86b585305cd6edc8ad6ea2a7c961154f2e" alt=""
前期考虑到可能要改编号,所以在每个编号后面加“ ”(空格),并保证文件名其他位置没有空格
data:image/s3,"s3://crabby-images/1f84c/1f84c1370de1c3172a31c6ce09f7cc10f70eae03" alt=""
用代码先在编号文件名前面 再加一个“29 ”的编号,判断添加顺序是否正确(万一有搞错项目的情况发生。)
import os
import time
path =r"D:\test\iVX\12 官网教程\04 营销互动(改编号)"
# UI搭建
a=29
fileList=os.listdir(path)
for file in fileList:
# split_str = file.split(' ')
# newname1 = split_str[0] # _的第0部分=序号
# newname2= split_str[1] # _的第0部分=序号
# newname=newname1+'mp4'
newname='{} '.format(a)+file
oldname_path = os.path.join(path,file)
# 文件新路径
newname_path = os.path.join(path,newname)
# 新旧对调
os.rename(oldname_path, newname_path)
a+=1
结果可以看到,左边的新编号与右边的错误号码差一位,说明新序号正确
data:image/s3,"s3://crabby-images/5b424/5b42453006f087c3422dd21917fbba0791d7037b" alt=""
再把文件名里面的第二个号码删除
import os
import time
path =r"D:\test\iVX\12 官网教程\04 营销互动(改编号)"
# UI搭建
fileList=os.listdir(path)
for file in fileList:
split_str = file.split(' ')
newname1 = split_str[0] # _的第0部分=序号
newname2= split_str[2] # _的第0部分=序号
# newname=newname1+'mp4'
newname=newname1+' '+newname2
oldname_path = os.path.join(path,file)
# 文件新路径
newname_path = os.path.join(path,newname)
# 新旧对调
os.rename(oldname_path, newname_path)
data:image/s3,"s3://crabby-images/cbd68/cbd68408e79fc9794602b6ad6981ef250911f380" alt=""
用同样的方法修改其他编号。顺利获得正确号码
data:image/s3,"s3://crabby-images/19b21/19b2162631c5b90e4fd3303fc6562d260ae4d8cf" alt=""
data:image/s3,"s3://crabby-images/e6a10/e6a1093a63b571407c3395e449588db95502cc8b" alt=""
data:image/s3,"s3://crabby-images/45541/45541fce44a0beac0794442bf79e4a27f7c43356" alt=""
data:image/s3,"s3://crabby-images/f44b4/f44b4f7ac86154e3c81087b6894c7029d85b7ba3" alt=""
运行两个代码有点麻烦。可以把两个代码组合在一起。
data:image/s3,"s3://crabby-images/e2bc3/e2bc36ef31fd4884047a6d14e9e33029c87b69b6" alt=""
import os
import time
path =r"D:\test\iVX\12 官网教程\\09 连接"
a=81
fileList=os.listdir(path)
for file in fileList:
split_str = file.split(' ') #空格作为分割点,提取1
newname1 = split_str[1] # _的第1部分=序号
newname='{} '.format(a)+newname1
# 删除了错误的序号,前面加上正确的序号空格
oldname_path = os.path.join(path,file)
# 文件新路径
newname_path = os.path.join(path,newname)
# 新旧对调
os.rename(oldname_path, newname_path)
a+=1
data:image/s3,"s3://crabby-images/44c8c/44c8ce9582368cc2c07a92ca7b71559e1eabdd8a" alt=""
问题:发现中间有两个空格
data:image/s3,"s3://crabby-images/7f27e/7f27e096476c3579154c1487c8bedea24aaa784d" alt=""
data:image/s3,"s3://crabby-images/b8f8e/b8f8e64321e566ee8a651e549b09793ffd05ae95" alt=""
path =r"D:\test\iVX\12 官网教程\kong"
fileList=os.listdir(path)
for file in fileList:
split_str = file.split(' ')
newname1 = split_str[0] # _的第0部分=序号
print(newname1)
newname2= split_str[2] # _的第0部分=序号
print(newname2)
newname=newname1+' '+newname2
oldname_path = os.path.join(path,file)
# 文件新路径
newname_path = os.path.join(path,newname)
# 新旧对调
os.rename(oldname_path, newname_path)
data:image/s3,"s3://crabby-images/6060f/6060f4cf1050388d947768466b2a75d31d2cca53" alt=""
data:image/s3,"s3://crabby-images/d193a/d193a7b96e97721a820688b0d3e5a7cdf94938ad" alt=""
空格一样大小(1个空格)
重要提示:
不能保证程序正确时,最好把数据备份
data:image/s3,"s3://crabby-images/ca856/ca856f000887f02369dc450852e2da80868062ac" alt=""
否则如果改名失败,文件名上的所有的信息都会被删除,无法恢复
data:image/s3,"s3://crabby-images/e37f3/e37f3962bfe23313a7b458fae83e7d504bf5e484" alt=""