爬bilibili网站视频

直接看效果:

背景:

为了从Bilibili(哔哩哔哩)视频分享平台上下载视频和音频,并将它们合并成一个完整的视频文件。Bilibili是中国非常流行的视频分享网站,用户可以在上面观看和分享各种类型的视频内容。由于Bilibili的视频和音频是分开存储的,因此需要分别下载并合并它们。

以下是代码的详细背景和功能说明:

  1. 导入必要的库

    • requests:用于发送HTTP请求。
    • json:用于解析JSON数据。
    • pprint:用于美化打印输出。
    • re:用于正则表达式操作。
    • os:用于操作系统相关功能,如文件和目录操作。
    • subprocess:用于执行系统命令。
    • sys:用于与Python解释器进行交互。
  2. 获取URL响应体

    • getResponse(url)函数发送一个GET请求到指定的URL,并返回响应对象。请求头中包含了refererUser-Agent,以模拟浏览器请求,避免被Bilibili服务器拒绝。
  3. 解析响应体

    • parseResponse(url)函数首先调用getResponse(url)获取响应体,然后使用正则表达式提取视频数据和标题。提取到的数据解析成JSON格式,从中获取音频和视频的URL,并封装成一个字典返回。
  4. 保存视频和音频

    • saveMedia(fileName, content, mediaType)函数用于将下载的音频和视频内容保存到本地文件系统中。文件保存在D:\\bilibili目录下,文件名为视频标题,扩展名根据媒体类型(音频为mp3,视频为mp4)确定。
  5. 合并音频和视频

    • AvMerge(Mp3Name, Mp4Name, savePath)函数使用ffmpeg工具将音频和视频合并成一个文件。合并后的文件保存在指定路径,并删除临时的音频和视频文件。
  6. 主函数

    • main()函数是程序的入口。用户输入Bilibili视频的URL,程序解析视频信息,下载音频和视频,并保存到本地。最后,调用AvMerge函数将音频和视频合并成一个完整的视频文件。

直接上代码:

import requests
import json
import pprint
import re
import os
import subprocess
import sys

"""获取url响应体"""
def getResponse(url):
    # 设置请求头
    headers = {
        'referer': 'https://www.bilibili.com/',
        'User-Agent': '你自己的'
    }
    # 发起get请求
    response = requests.get(url=url, headers=headers)
    return response

"""解析响应体"""
def parseResponse(url):
    # 获取url响应体
    response = getResponse(url)
    # 用正则表达式取出返回的视频数据
    html_data = re.findall('<script>window.__playinfo__=(.*?)</script>', response.text)[0]
    # 解析成json数据
    jsonData = json.loads(html_data)
    # 获取视频标题
    videoTitle = re.findall('<title data-vue-meta="true">(.*?)</title>', response.text)[0]
    # 获取音频
    audioUrl = jsonData['data']['dash']['audio'][0]['baseUrl']
    # 获取视频
    videoUrl = jsonData['data']['dash']['video'][0]['baseUrl']
    # 封装视频信息
    videoInfo = {
        'videoTitle': videoTitle,
        'audioUrl': audioUrl,
        'videoUrl': videoUrl,
    }
    print("获取Response信息成功!")
    return videoInfo

"""保存视频和音频"""
def saveMedia(fileName, content, mediaType):
    # 创建目录(如果不存在)
    os.makedirs('D:\\bilibili', exist_ok=True)
    # 写入文件
    with open(f'D:\\bilibili\\{fileName}.{mediaType}', mode='wb') as f:
        f.write(content)
    print(f"保存{mediaType}成功!")

def AvMerge(Mp3Name, Mp4Name, savePath):
    print("开始合并音频和视频.........")
    print(f"音频文件: {Mp3Name}")
    print(f"视频文件: {Mp4Name}")
    print(f"合并后文件保存路径: {savePath}")

    # 使用subprocess来调用ffmpeg,并重定向输出
    with open(os.devnull, 'w') as devnull:
        result = subprocess.run(
            ['ffmpeg', '-i', Mp4Name, '-i', Mp3Name, '-c:v', 'copy', '-c:a', 'aac', '-strict', 'experimental', savePath],
            stdout=devnull,
            stderr=devnull
        )

    print("合并成功!")
    os.remove(Mp3Name)
    os.remove(Mp4Name)

def main():
    url = input("请输入B站视频url地址:")
    videoInfo = parseResponse(url)
    # 获取视频标题
    fileName = videoInfo['videoTitle']
    # 下载并保存音频
    audioContent = getResponse(videoInfo['audioUrl']).content
    saveMedia(fileName, audioContent, 'mp3')
    # 下载并保存视频
    videoContent = getResponse(videoInfo['videoUrl']).content
    saveMedia(fileName, videoContent, 'mp4')

    Mp3Name = f'D:\\bilibili\\{fileName}.mp3'
    Mp4Name = f'D:\\bilibili\\{fileName}.mp4'
    savePath = f'D:\\bilibili\\merge_{fileName}.mp4'
    AvMerge(Mp3Name, Mp4Name, savePath)


if __name__ == '__main__':
    main()

  • 8
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在B站下载指定视频的过程中,可以使用爬虫技术来实现。首先,你需要准备好爬虫工具和相关的编程环境。接下来,你可以使用Python编写爬虫代码来实现下载功能。 一种常见的方法是通过解析B站视频页面的源代码来获取视频的URL链接。你可以使用正则表达式或者BeautifulSoup等库来提取视频的URL链接。在提取URL链接之前,你需要找到视频文件所在的位置,一般是在video标签中。 在提取到视频的URL链接之后,你可以使用Python的下载库来下载视频文件。固定的文件格式可能是MP4或者其他一些常见的视频格式。你可以使用requests库来发送GET请求并下载视频文件。 但需要注意的是,B站对于视频的下载有一些防护措施,比如防盗链机制。这意味着你在下载视频时可能需要设置Referer头信息,以绕过防盗链。你可以使用requests库来添加Referer头信息并发送请求。 总结起来,通过编写爬虫代码,你可以解析B站视频页面源代码,提取视频的URL链接,并使用下载库下载视频文件,同时需要注意处理防盗链机制。这样就能够实现下载B站指定视频的功能。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [送书 | 教你下载B站指定视频](https://blog.csdn.net/tongtongjing1765/article/details/120558933)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

LucianaiB

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值