批量下载B站视频的方法


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

 


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM