利用python模糊查询批量修改文件名
程序员文章站
2022-06-24 16:49:54
今天利用哔哩哔哩下载器下载了一堆资源,结果发现文件名全部都是乱序,没有排好序就感觉看的很蒙,突然想起python可以批量重命名于是准备利用python写一个脚本.大概思路就是先爬取哔哩哔哩视频的标题,爬取下来后利用range生成顺序编号,通过字符串拼接起来,然后截取文件夹的名字,拿着截取的名字去查找对应的新名字和旧名字,利用python的os模块进行批量重命名,以下是实现代码:导入相关库import requests #python请求库import json#处理json数据库impo...
今天利用哔哩哔哩下载器下载了一堆资源,结果发现文件名全部都是乱序,没有排好序就感觉看的很蒙,突然想起python可以批量重命名于是准备利用python写一个脚本.
大概思路就是先爬取哔哩哔哩视频的标题,爬取下来后利用range生成顺序编号,通过字符串拼接起来,然后截取文件夹的名字,拿着截取的名字去查找对应的新名字和旧名字,利用python的os模块进行批量重命名,以下是实现代码:
- 导入相关库
import requests #python请求库
import json #处理json数据库
import os #os系统模块
import fnmatch #模糊查找库
- 获取哔哩哔哩视频下的标题,https://api.bilibili.com/x/web-interface/view/detail?bvid=av号&aid=av号的aid可以通过f12获取,url中的aid就是图片里的pid
还有一个接口不过需要自己处理一下json数据,此代码用的上面那个接口,接口地址:https://api.bilibili.com/x/player/pagelist?bvid=AV号&jsonp=jsonp
# 获取哔哩哔哩视频的每集的标题
def getjson():
page_text = requests.get(
'https://api.bilibili.com/x/web-interface/view/detail?bvid=BV15741177Eh&aid=89760569')
data = page_text.json()
shuzi = list(range(1, 233))
data = data['data']['View']['pages']
newname = []
for shuzi, item in zip(shuzi, data):
part = item['part']
mingzi = str(shuzi)+part[3:len(part)]+".mp4"
newname.append(mingzi)
return newname#将整理好的newname返回出去
- 截取需要查找的字符串
# 截取需要查找的字符串
def findName(fileList):
findname = []
for fn in fileList:
fname = fn[7:len(fn)-12]
findname.append(fname)
return findname
- 查找需要更改的需要更改的文件名字以及新名字
# 查找需要更改的需要更改的文件名字以及新名字
def comparison(fileList, path):
oa = [] # 定义需要更改的文件名字的列表
newa = [] # 定义新名字的列表
findname = findName(fileList) # 获取查找字符串的列表
newname = getjson() # 获取哔哩哔哩新名字的列表
# 循环遍历查找字符串和需要更改的文件名字
for fn, oldname in zip(findname, fileList):
# 循环新名字保证每一个查找字符串可以和每一个新名字以及每一个需要更改的文件名字可以对比
for na in newname:
# 使用模糊查询,找出对应的新名字以及需要更改的文件名字,
if fn in oldname and fn in na and oldname.endswith('.mp4'):
# fn 查找字符串,oldname需要更改的文件名字,na新名字
oa.append(oldname)
newa.append(na)
rename(oa, newa, path)
- 进行批量重命名
def rename(oldname, newname, path):
path = path # 文件路径
oldname = oldname # 需要更改的文件名字
newname = newname # 新名字
# 文件批量重命名
for oldn, newna in zip(oldname, newname):
# 捕获异常使其遇到错误也可以正常运行,因为模糊查询的原因避免不了重名的错误,所以只能把准确率控制在90%
try:
oldname = path + os.sep + oldn
newname = path + os.sep + newna
os.rename(oldname, newname)
print(oldname, '=======>', newname)
except Exception as e:
pass
- 定义主函数
if __name__ == "__main__":
path = 'D:\Learning world\personal project\personal project\Python\\test'#路径
fileList = os.listdir(path)#列取path下的文件名
comparison(fileList, path)
注意
github代码:https://github.com/JiangJiYue/PythonCrawler/blob/main/bilibili.py
请复制出一份后在测试代码
未整理前:
整理后:
本文地址:https://blog.csdn.net/qq_41714951/article/details/110918440
上一篇: 2020-12-10
下一篇: MySQL 学习记录 03