05、Python -- 爬取ts文件格式视频思路

思路:
1、爬取视频,但是每次只能爬取一段5秒的视频。
2、一个视频有很多秒,所以需要爬取很多片段的视频
3、把所有爬取下来的片段视频合成导出。

4、最后再简洁代码

第一步:爬取一段5秒视频

找url

首先,找到需要爬取的视频,选择如图,找到对应的URL。
在这里插入图片描述

代码

然后最简单的四行爬取代码
在这里插入图片描述

结果

爬取的结果如图,里面视频只有5秒
在这里插入图片描述

第二步:下载整个视频的所有片段

代码:

在这里插入图片描述

结果:

在这里插入图片描述
把该视频所有片段都下载下来了
在这里插入图片描述

第三步:合成视频

安装模块

命令:pip install moviepy -i https://mirrors.aliyun.com/pypi/simple/

在这里插入图片描述

代码:

在这里插入图片描述

结果

在这里插入图片描述

完整合成视频并下载下来
在这里插入图片描述

简洁代码

代码:

在这里插入图片描述

结果:

在这里插入图片描述
如图:每个视频只由4秒
在这里插入图片描述

在这里插入图片描述

最终代码

简洁前代码

这里我把原本存放视频的文件夹名由《视频》改成《视频片段》
在这里插入图片描述
所以这里的【视频】,后面写代码的时候也应该改成【视频片段】
在这里插入图片描述

# 导入模块
import requests

number = 0
# 循环下载视频片段
while True:
    format_num = '{:05d}'.format(number)
    # f'' --> 用于在字符串中添加执行表达式
    url = f'https://xxxxxxxxxx.{format_num}.ts?pkexxxxxxxxxxxxx'
    res = requests.get(url)
    # 遇到404,就跳出循环
    if res.status_code == 404:
        break
    open(f'视频片段/{format_num}.ts', 'wb').write(res.content)
    print(f'已经下载了 {format_num}.ts文件')
    number += 1

print(f'一共下载了 {number} 个视频 , 准备合成,请稍等几分钟')



# 合成
#从moviepy这个模块的子模块editor里面导入所有的功能
from moviepy.editor import *

# 列表 把这些视频加载到程序中来,保存在一个列表中
clip_list = []
for i in range(number):
    format_num = '{:05d}'.format(i)
    clip = VideoFileClip(f'视频片段/{format_num}.ts')
    clip_list.append(clip)


# 最终视频合成
lastVideo = concatenate_videoclips(clip_list)
# 视频下载写出地址
lastVideo.write_videofile('完整视频/最终视频.mp4')

简洁后代码

# 导入模块
import requests
#从moviepy这个模块的子模块editor里面导入所有的功能
from moviepy.editor import *
number = 0
# 列表, 用于把所有片段视频加载到程序中来,保存在一个列表中
clip_list = []
# 循环下载视频片段
while True:
    format_num = '{:05d}'.format(number)
    # f'' --> 用于在字符串中添加执行表达式
    url = f'https://xxxxxxxhevc_1.{format_num}.ts?pkexxxxxxxxxxxxxxxxxxxxxx'
    res = requests.get(url)
    # 遇到404,就跳出循环
    if res.status_code == 404:
        break
    # 视频片段 就是存放一段段视频的文件夹名
    open(f'视频片段/{format_num}.ts', 'wb').write(res.content)
    clip = VideoFileClip(f'视频片段/{format_num}.ts')
    clip_list.append(clip)
    print(f'已经下载了并且加载了 {format_num}.ts文件')
    number += 1
print(f'一共下载了 {number} 个视频 , 准备加载,请稍等几分钟')
# 最终视频合成
lastVideo = concatenate_videoclips(clip_list)
# 视频下载写出地址
lastVideo.write_videofile('完整视频/最终视频.mp4')

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

_L_J_H_

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

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

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

打赏作者

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

抵扣说明:

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

余额充值