【爬虫】爬bibi视频

1. 复制粘贴搜索

2. 利用工具写请求代码

工具网址:Convert curl commands to code

3. 把爬取内容喂给ai

先保存到txt文件

复制代码
# 上面代码是第二部分复制粘贴的
with open('1.txt', 'w') as f:
    f.write(response.text)

问ai:根据txt的内容,查找并提取视频地址和音频地址

以下是ai返回的:

复制代码
import requests
import re
import json

url = 'https://www.bilibili.com/video/BV11GJazAE35/'
headers = {
    'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.0.0.0 Safari/537.36',
    'Referer': 'https://www.bilibili.com/'
}

response = requests.get(url, headers=headers)
html = response.text

# 方法1:从window.__playinfo__中提取
match = re.search(r'window.__playinfo__=(.*?)</script>', html)
if match:
    play_info = json.loads(match.group(1))
    # 视频地址
    video_url = play_info['data']['dash']['video'][0]['baseUrl']
    # 音频地址
    audio_url = play_info['data']['dash']['audio'][0]['baseUrl']
    print(f"视频地址: {video_url}")
    print(f"音频地址: {audio_url}")

运行结果:

4. 合并视频和音频

这一步我直接 按tab键自动补全的,参考以下代码:

复制代码
from moviepy import VideoFileClip, AudioFileClip
# 加载视频和音频文件
video_clip = VideoFileClip("视频.mp4")
audio_clip = AudioFileClip("视频.mp3")

# 将音频设置为视频的音频
video_clip = video_clip.with_audio(audio_clip)

# 保存合并后的视频
video_clip.write_videofile("合并后的视频.mp4")

完整代码如下:

复制代码
import requests
import re
import json

url = 'https://www.bilibili.com/video/BV11GJazAE35/'
headers = {
    'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/121.0.0.0 Safari/537.36',
    'Referer': 'https://www.bilibili.com/'
}

response = requests.get(url, headers=headers)
html = response.text

# 方法1:从window.__playinfo__中提取
match = re.search(r'window.__playinfo__=(.*?)</script>', html)
if match:
    play_info = json.loads(match.group(1))
    # 视频地址
    video_url = play_info['data']['dash']['video'][0]['baseUrl']
    # 音频地址
    audio_url = play_info['data']['dash']['audio'][0]['baseUrl']
    print(f"视频地址: {video_url}")
    print(f"音频地址: {audio_url}")

# 视频
with open('视频.mp4', 'wb') as f:
    f.write(requests.get(video_url, headers=headers).content)
# 音频
with open('视频.mp3', 'wb') as f:
    f.write(requests.get(audio_url, headers=headers).content)


from moviepy import VideoFileClip, AudioFileClip
# 加载视频和音频文件
video_clip = VideoFileClip("视频.mp4")
audio_clip = AudioFileClip("视频.mp3")

# 将音频设置为视频的音频
video_clip = video_clip.with_audio(audio_clip)

# 保存合并后的视频
video_clip.write_videofile("合并后的视频.mp4")

效果如下:

视频也是有声音的。

说明:爬的视频不是高清的,想爬高清的得登陆,在代码中增加对应的参数与请求头等,比如cookie值等。

相关推荐
海边的梦9 小时前
【无标题】
爬虫·网络爬虫
@我漫长的孤独流浪12 小时前
Python爬虫实战:从入门到精通
开发语言·爬虫·python
小白学大数据14 小时前
如何判断网站流量飙升是搜索引擎爬虫导致的?
爬虫·scrapy·搜索引擎·pycharm
devnullcoffee14 小时前
亚马逊ASIN数据批量采集技术选型:工具 vs 自建爬虫 vs Scrape API vs AI Agent完整对比
人工智能·爬虫·agent·亚马逊运营·openclaw·亚马逊 asin 数据采集
MuShan-bit14 小时前
CSDN-推荐开源项目-auto-x-to-wechat
爬虫·微信·开源·node.js·twitter
小鸡吃米…15 小时前
Python 网络爬虫
开发语言·爬虫·python
anzhxu1 天前
maxun爬虫机器人介绍与部署
爬虫
小心我捶你啊1 天前
提升爬虫稳定性的关键,Python爬虫代理IP解析与轮换策略
爬虫·python·tcp/ip
xdl25991 天前
【Python学习】网络爬虫-爬取豆瓣电影评论
爬虫·python·学习
袁袁袁袁满1 天前
基于亮数据MCP与LangGraph集成实现爬虫自动化
爬虫·python·网络爬虫·数据采集·爬虫实战·自动化采集·爬虫案例