写点什么

python 爬取下载 m3u8 加密视频,原来这么简单!

发布于: 19 小时前

1.前言

爬取视频的时候发现,现在的视频都是经过加密(m3u8),不再是 mp4 或者 avi 链接直接在网页显示,都是经过加密形成 ts 文件分段进行播放。


今天就教大家如果通过 python 爬取下载 m3u8 加密视频

2.分析网页

1.电影视频来源

http://www.caisetv.com/
复制代码


2.分析 m3u8 加密目录

http://www.caisetv.com/dongzuopian/chaidanzhuanjia/0-1.html
复制代码



在视频播放的页面,通过 F12 可以查看网络数据包


https://xigua-cdn.haima-zuida.com/20210219/19948_fcbc225a/1000k/hls/index.m3u8
复制代码



这里的 ts 就电影的加密分段视频


https://xigua-cdn.haima-zuida.com/20210219/19948_fcbc225a/1000k/hls/
复制代码


上面的 m3u8 链接掉 index.m3u8 后,在拼上 075a34cccdd000000.ts 等 ts 名称就是分段视频的链接


如下所示:


https://xigua-cdn.haima-zuida.com/20210219/19948_fcbc225a/1000k/hls/075a34cccdd000000.ts
复制代码


通过浏览器把这个分段视频下载后打开:



所以只要把所有的 ts 下载并合并就是完整的电影视频!!!

3.下载 ts

1.下载 ts 分段视频

刚刚已经把 ts 的所有名称下载下来了



接下来通过 python 代码去读取这个文件,提取出名称,拼接链接后下载保存到一个文件夹里!


headers = {'User-Agent': 'Mozilla/5.0 (Windows NT 6.3; Win64; x64; rv:84.0) Gecko/20100101 Firefox/84.0',}  ###下载ts文件def download(url,name):    r = requests.get(url, headers=headers)    with open(name+"", "wb") as code:        code.write(r.content)  with open("index.m3u8","r") as f:    ts_list = f.readlines()  #去掉前面没用的信息ts_list = ts_list[5:]urlheader="https://xigua-cdn.haima-zuida.com/20210219/19948_fcbc225a/1000k/hls/"count = 0for i in ts_list:    if "#" not in i:        i = i.replace("\n","")        download(urlheader+""+i,"cdzj2/"+str(count)+".ts")        count = count+1        print(count)
复制代码



这样就可以把 ts 文件全部下载下来,但是一个一个下载很慢,下面通过多线程下载,提升下载速度!!!

2.多线程下载 ts 视频

for i in ts_list:    if "#" not in i:        i = i.replace("\n","")        n = i[-7:]        threading.Thread(target=download, args=(urlheader+""+i,"cdzj2/"+str(n),)).start()        #download(urlheader+""+i,"cdzj2/"+str(count)+".ts")
复制代码



通过多线程很快就可以将这些 ts 文件下载到本地!!!

4.合并 ts

cmd 合并文件

copy /b   *.ts   new.mp4
复制代码


通过这个命令(cmd 终端中运行),在含有 ts 文件的文件夹中就可以将 ts 文件合并(按名称顺序进行排列合并),并保存成 new.mp4



5.总结

  1. 分析 m3u8 加密文件

  2. python 下载 ts 文件

  3. cmd 合并 ts 保存成 mp4 格式

发布于: 19 小时前阅读数: 9
用户头像

个人公众号:Python研究者 2021.04.26 加入

教你如何学Python,专注于Python入门与进阶、爬虫、数据分析挖掘、数据可视化。分享Python相关的技术文章、工具资源、视频教程、学习资料。

评论

发布
暂无评论
python爬取下载m3u8加密视频,原来这么简单!