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