爬虫学习—小破站爬取单个视频

目标url:【颜值主播】快来快来,一粟小莎子蓝色战衣限时返场~_哔哩哔哩_bilibili

(输入目标url后记得加一个空格,再按回车键)

import requests
from lxml import etree
import re
from moviepy.editor import *

if __name__ == '__main__':
    # 输入播放页面的url
    url_ = input('请输入播放页面的url:')

    # 设置用户代理,cookie
    headers_ = {
        'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36',
        'referer': 'https://search.bilibili.com/all?vt=19210094&keyword=%E4%B8%80%E7%B2%9F%E5%B0%8F%E8%8E%8E%E5%AD%90&from_source=webtop_search&spm_id_from=333.1007&search_source=3'
    }

    # 发送请求,得到响应对象
    response_ = requests.get(url_,headers=headers_)

    str_data = response_.text  # 视频主页的html代码,类型是字符串

    # 使用xpath解析html代码,得到想要的url
    html_obj = etree.HTML(str_data)  # 转换格式类型

    # 使用xpath语法获取数据
    # 取到数据为列表,索引[0]取值取出里面的字符串,即包含纯视频纯音频文件的url字符串
    url_list_str = html_obj.xpath("//script[contains(text(),'window.__playinfo__')]/text()")[0]

    # 使用正则提取纯视频url
    video_url = re.findall(r'"video":\[{"id":\d+,"baseUrl":"(.*?)"',url_list_str)[0]

    # 使用正则提取纯音频url
    audio_url = re.findall(r'"audio":\[{"id":\d+,"baseUrl":"(.*?)"',url_list_str)[0]

    # 设置灵活的headers
    headers_ = {
        'user-agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/108.0.0.0 Safari/537.36',
        'referer': url_
    }

    # 获取纯视频的数据
    response_video = requests.get(video_url,headers=headers_)
    bytes_video = response_video.content
    # 获取纯音频的数据
    response_audio = requests.get(audio_url,headers=headers_)
    bytes_audio = response_audio.content

    # 保存
    with open('一粟小莎子.mp4','wb') as f:
        f.write(bytes_video)
        print('纯视频文件下载完毕....')
    with open('一粟小莎子.mp3','wb') as f:
        f.write(bytes_audio)
        print('纯音频文件下载完毕....')

    ffmpeg_tools.ffmpeg_merge_video_audio('一粟小莎子.mp4', '一粟小莎子.mp3', '颜值主播.mp4')
    print('视频合成成功....')

8d9b32af3da844c98bcccb2eebf9ee14.png

 5ccdc742788c44b7912956afad97f822.png

 

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值