首先分析下b站的视频地址构成,如https://www.bilibili.com/video/BV1BW411R7QK?p=1,是由视频编号加节数组成,如p=1代表视频列表的第一集, p=2等与视频第二集。
所以类似爬虫,我们可以循环使用脚本命令和第三下载工具,如wget或you-get(Python)实现批量下载
以Python结合you-get为例
import os
# 检测you-get是否安装,否则自动安装
retu = os.popen('you-get').read()
if not 'OPTION' in retu:
print('安装you-get中 . . .')
os.system('pip install you-get')
print('you-get已就绪!')
else:
print('you-get已就绪!')
savePath = r'D:\Bilibili' # 视频下载目标文件夹
if not os.path.exists(savePath):
os.makedirs(savePath)
# 循环拼接网址https://www.bilibili.com/video/BV1BW411R7QK?p=1
downloadPath = r'https://www.bilibili.com/video/BV1r541147cZ?p='
for page in range(1, 20):
url = downloadPath + str(page)
cmd = 'you-get ' + ' --format=flv720 ' + url + ' -o ' + savePath # 字符串拼接you-get命令,--format 指定视频质量,不带该参数则默认1080P
os.system(cmd)
可以修改range范围,开启多个不同脚本来增加下载速度,测试最大支持5个进程同时下载。
注意停止下载前,务必手动终止脚本,否则有可能会被拉黑IP,导致当天无法继续下载。