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 = 0
for i in ts_list:if "#" not in i:i = i.replace("\n","")download(urlheader+""+i,"cdzj2/"+str(count)+".ts")count = count+1print(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格式

如果大家对本文代码源码感兴趣,扫码关注『Python爬虫数据分析挖掘』后台回复:爬取m3u8,获取完整代码。

------------- 推荐文章 -------------

1爬取1907条『课程学习』数据,分析哪类学习资源最受大学生青睐


2.以『B站』为实战案例!手把手教你掌握爬虫必备框架『Scrapy』


3.python爬取各类基金数据,以『动图可视化』方式展示基金的涨跌情况

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

  1. 用python爬取下载b站视频

    B站之所以火,是因为趣味与知识并存.正如一句"你在B站看番,我在B站学习",B站还是有一些质量比较好的学习视频.当你在B站上看到喜欢的视频想保存下来时,怎么办呢? 转入正题,本篇推 ...

  2. python自动搜索爬取下载文件-python批量爬取下载抖音视频

    本文实例为大家分享了python批量爬取下载抖音视频的具体代码,供大家参考,具体内容如下 import os import requests import re import sys import a ...

  3. python爬取抖音用户数据_python批量爬取下载抖音视频

    本文实例为大家分享了python批量爬取下载抖音视频的具体代码,供大家参考,具体内容如下 import os import requests import re import sys import a ...

  4. Python爬虫学习,批量爬取下载抖音视频

    这篇文章主要为大家详细介绍了python批量爬取下载抖音视频,具有一定的参考价值,感兴趣的小伙 项目源码展示 ''' 注:如果你对python感兴趣,我这有个学习Python基地,里面有很多学习资料, ...

  5. Python爬虫学习教程,批量爬取下载抖音视频

    这篇文章主要为大家详细介绍了python批量爬取下载抖音视频,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 项目源码展示: ''' 在学习过程中有什么不懂得可以加我的 python学习交流扣扣qu ...

  6. python 爬取B站原视频的实站代码

    本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理 以下文章来源于腾讯云,作者:python学习教程 ( 想要学习Python?Pyt ...

  7. 下载m3u8加密视频的一些经验和小细节

    这里有一个神器,使用非常方便,不用看下边的了 链接 一.下载ts分片 1.桌面上建立一个文件夹 2.下载index.m3u8,查看多少个ts分片 3.idm下载ts分片到该文件夹 4.复制刚才的ind ...

  8. python实战(一)Python爬取猫眼评分排行前100电影及简单数据分析可视化python实战(一)Python爬取猫眼排行前一百电影及简单数据分析可视化

    python实战(一)Python爬取猫眼排行前一百电影及简单数据分析可视化 一.抓取数据 需要的库 request库 响应http请求 json库 将文本保存成json形式 pyquery 类似JQ ...

  9. Python爬取网站图片并保存,超级简单

    Python爬取网站图片并保存,超级简单 先看看结果吧,去bilibili上拿到的图片=-= 第一步,导入模块 import requests from bs4 import BeautifulSou ...

最新文章

  1. 使用python建立简单的单链表
  2. 设计中的版面艺术!你造吗?(四)
  3. linux shell 变量减法_第四章 shell和环境变量
  4. 微型计算机原理及应用程序题,郑学坚《微型计算机原理及应用》(第4版)笔记和课后习题详解...
  5. java.util -- List接口
  6. 【Selenium】之谷歌、IE、火狐浏览器各个版本的浏览器驱动下载地址
  7. Lambda学习笔记
  8. [Python] L1-022. 奇偶分家-PAT团体程序设计天梯赛GPLT
  9. Bailian2726 采药【模拟】
  10. java百度贴吧一键签到,手机百度贴吧怎么一键签到?手机贴吧一键签到怎么用?
  11. linux打印机设置密码,linux桌面打印机配置指南 | 高蛋白网
  12. 对ID3算法的理解及其优缺点
  13. 百度网盘加速下载方法——系统自带的提速模式和积分模式区别
  14. 中国超级稻在18个亚非国家试种推广 国稻种芯百团计划行动
  15. 推荐一个博客:香樟小院-大宝系列,博主多年来坚持记录了一只叫大宝的野猫的生活点滴,大宝后来还有了个小宝.......
  16. IE8浏览器为什么没有工具-internet选项
  17. 基于工作流平台的ITSM系统
  18. 5 kyu some egyptian fractions
  19. 半夜开piao竟然被罚
  20. 浴火重生的Firebird

热门文章

  1. Mac OSX下使用VMware Fusion 配置静态IP 图文教程指南
  2. 电脑连接无线网网速慢,同局域网下其他电脑网速却不慢
  3. Excel 物料BOM根据位号计算用量公式
  4. ESP32设备驱动-HMC5883L磁场传感器驱动
  5. Oracle(四)Oracle 函数
  6. Oracle运维日记
  7. Win10图片打开很慢如何改回Win7的图片查看器打开?
  8. 关于IIC总线的若干问题
  9. BCC异或校验及BCC在Matlab中的实现
  10. kyeremal-网络流24题T2-太空飞行计划问题