首先分析下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,导致当天无法继续下载。