爬虫下载b站视频

复制代码
#知识点
#Requests模块使用
#Json数据提取
#re模块使用
#os模块使用
#ffmpeg工具使用
import json
import os
import pprint
import re
from lxml import etree

#1.爬取视频页的网页源代码
import requests
headers={
    'referer':'https://www.bilibili.com',
    'User-Agent':'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/126.0.0.0 Safari/537.36'
}
def get_paly_url(url):
    r=requests.get(url,headers=headers)
    #2.提取视频和音频的播放地址
    info=re.findall('window.__playinfo__=(.*?)</script>',r.text)[0]
    video_url=json.loads(info)['data']['dash']['video'][0]['baseUrl']
    audio_url=json.loads(info)['data']['dash']['audio'][0]['baseUrl']
    html=etree.HTML(r.text)
    filename=html.xpath('//h1/text()')[0]
    # print(filename)
    return video_url,audio_url,filename
#3.下载并保存视频和音频
def download_files(video_url,audio_url,filename,path):
    print('开始下载音频和视频...')
    video_content=requests.get(video_url,headers=headers).content
    audio_content = requests.get(audio_url, headers=headers).content
    with open(f'{path}/{filename}.mp4','wb') as f:
        f.write(video_content)
        print('已下载视频部分')
    with open(f'{path}/{filename}.mp3', 'wb') as f:
        f.write(audio_content)
        print('已下载音频部分')

#4.合并视频和音频
#ffmpeg
def combine_files(filename,path):
    cmd=fr"D:\python学习笔记课后题\ffmpeg-7.0.1-full_build\ffmpeg-7.0.1-full_build\bin\ffmpeg -i {path}\{filename}.mp4 -i {path}\{filename}.mp3 -c:v copy -c:a aac -strict experimental {path}\output-{filename}.mp4 -loglevel quiet"
    os.system(cmd)
    print('已完成合并!')
    os.remove(f'{path}\{filename}.mp4')
    os.remove(f'{path}\{filename}.mp3')
    print('已删除多余文件!')
if __name__ == '__main__':
    path = 'D:\python学习笔记课后题\爬虫\实战\视频'
    url = 'https://www.bilibili.com/video/BV1AA4y1D7h2/?spm_id_from=333.337.search-card.all.click'
    video_url,audio_url,filename=get_paly_url(url)
    download_files(video_url, audio_url, filename, path)
    combine_files(filename, path)
相关推荐
深蓝电商API2 小时前
Selenium 截图与元素高亮定位技巧
爬虫·python·selenium
喵手14 小时前
Python爬虫零基础入门【第九章:实战项目教学·第1节】通用新闻采集器:从零打造可复用的静态站模板!
爬虫·python·爬虫实战·python爬虫工程化实战·零基础python爬虫教学·新闻采集器·静态站模版
嫂子的姐夫17 小时前
25-jsl:gov公安(全扣补环境版)
爬虫·逆向·加速乐
喵手18 小时前
Python爬虫零基础入门【第九章:实战项目教学·第2节】“接口优先“项目:从 Network 还原 JSON 接口分页!
爬虫·python·python爬虫实战·python爬虫工程化实战·python爬虫零基础入门·接口优先·json接口分页
却道天凉_好个秋19 小时前
音视频学习(八十六):宏块
音视频·hevc·宏块·ctu
喵手19 小时前
Python爬虫零基础入门【第九章:实战项目教学·第8节】限速器进阶:令牌桶 + 动态降速(429/5xx)!
爬虫·python·令牌桶·python爬虫工程化实战·python爬虫零基础入门·限速器·动态降速
喵手19 小时前
Python爬虫零基础入门【第九章:实战项目教学·第3节】通用清洗工具包:日期/金额/单位/空值(可复用)!
爬虫·python·python爬虫实战·python爬虫工程化实战·python爬虫零基础入门·通用清洗工具包·爬虫实战项目
喵手19 小时前
Python爬虫零基础入门【第九章:实战项目教学·第4节】质量报告自动生成:缺失率/重复率/异常值 TopN!
爬虫·python·爬虫实战·python爬虫工程化实战·零基础python爬虫教学·实战项目教学·质量报告自动生成
喵手19 小时前
Python爬虫零基础入门【第九章:实战项目教学·第7节】增量采集:last_time / last_id 两种策略各做一遍!
爬虫·python·爬虫实战·python爬虫工程化实战·零基础python爬虫教学·增量采集·策略采集
小咖自动剪辑20 小时前
AI 智能视频无损放大工具:支持超分辨率与智能补帧
人工智能·音视频·智能电视