successok

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

 

分类:

技术点:

相关文章: