python实现将m3u8视频转换成mp4的操作步骤!
python实现将m3u8视频转换成mp4的操作步骤!
首先,网上获取m3u8视频
第一种,浏览器控制面板下,定位的Sources的tab, 在右侧的XHR/fetch Breakpoints下添加过滤,如下图所示,如果它访问的网络有对应的过滤条件,会断点暂停,此时可以获取到ts文件
第二种,浏览器控制面板下,定位到Network的tab,下面子集的tab选中Fetch/XHR, 同时在搜索框输入'ts',如下图所示,重新刷新浏览器,如果接口访问存在对应的过滤条件,列表中会有对应的访问接口
其次,将m3u8视频转换成各个ts文件
第一步,我们通过python的requests请求m3u8链接,它会返回文件的内容,m3u8的数据结构如下图所示。具体每个表示什么意思,网上都可以搜,不具体介绍。主要关心我们需要的各个ts。我们通过“\n”将内容分开,会发现ts的前面是不带“#”号的
根据自己的情况,ts的链接拼完整,通过requests将获取到的内容保存到本地。这里采用并行的方式(asyncio + aiohttp), 将所有的ts下载列表放在asyncio.gather中,aiohttp去请求远程ts,达到并行下载的效果
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
import requests import os import asyncio import aiohttp dirname = 'tsLib' if not os.path.exists(dirname): os.mkdir(dirname) headers = { 'User-Agent' : 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/123.0.0.0 Safari/537.36' } async def download_ts(session, url, name): async with session.get(url, headers = headers) as response: data = await response.read() with open (os.path.join(dirname, name + '.ts' ), mode = 'wb' ) as f: f.write(data) async def analysis_m3u8(data): filtered_content = data.split( "\n" ) tasks = [] async with aiohttp.ClientSession() as session: for index, line in enumerate (filtered_content): if not line.startswith( '#' ): url = f 'https://c-vod.hw-cdn.xiaoeknow.com/522ff1e0vodcq1252524126/9f5770b41397757889226643080/{line}' name = line.split( '.' )[ 0 ] print (name, 'namename' ) tasks.append(download_ts(session, url, name)) await asyncio.gather( * tasks) print ( "Downloads completed." ) def get_m3u8(url): response = requests.get(url = url, headers = headers) m3u8_data = response.text return m3u8_data.strip() async def main(): m3u8_url = "https://c-vod.hw-cdn.xiaoeknow.com/522ff1e0vodcq1252524126/9f5770b41397757889226643080/playlist_eof.m3u8?sign=e6575d5fa9576eedbbc505cd53ca9ab5&t=66296146&us=xicXbvVMwn" m3u8_data = get_m3u8(m3u8_url) await analysis_m3u8(m3u8_data) asyncio.run(main()) |
最后,将ts文件合并为mp4文件
这里主要采用ffmpeg方式将ts合并为mp4, 但因为上面下载的顺序按照ts名字来的,不一定有顺序。所以我采用将m3u8获取文件的顺序、数组存储,然后合并ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
|
import os import subprocess import requests headers = { 'User-Agent' : 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/123.0.0.0 Safari/537.36' } def get_m3u8(url): response = requests.get(url = url, headers = headers) m3u8_data = response.text return m3u8_data.strip() def getFiles(): m3u8_url = "https://c-vod.hw-cdn.xiaoeknow.com/522ff1e0vodcq1252524126/9f5770b41397757889226643080/playlist_eof.m3u8?sign=e6575d5fa9576eedbbc505cd53ca9ab5&t=66296146&us=xicXbvVMwn" m3u8_data = get_m3u8(m3u8_url) filtered_content = m3u8_data.split( "\n" ) files = [] for index, line in enumerate (filtered_content): if not line.startswith( '#' ): name = line.split( '.' )[ 0 ] files.append(f '{name}.ts' ) return files def merge_ts_to_mp4(ts_dir, output_mp4): files = getFiles() # Sort the filenames based on the numbers after the underscore ts_files = [f for f in files if f.endswith( '.ts' )] ts_paths = [os.path.join(ts_dir, f) for f in ts_files] print (ts_paths, '00999' ) # Generate a list of arguments for ffmpeg command ffmpeg_args = [ 'ffmpeg' , '-i' , 'concat:' + '|' .join(ts_paths), '-c' , 'copy' , output_mp4] # Run ffmpeg command subprocess.run(ffmpeg_args) print ( "Merged all .ts files into" , output_mp4) # Example usage: ts_dir = 'tsLib' output_mp4 = 'merge_ts.mp4' merge_ts_to_mp4(ts_dir, output_mp4) |
以上就是python实现将m3u8视频转换成mp4的操作步骤的详细内容。
学习资料见知识星球。
以上就是今天要分享的技巧,你学会了吗?若有什么问题,欢迎在下方留言。
快来试试吧,小琥 my21ke007。获取 1000个免费 Excel模板福利!
更多技巧, www.excelbook.cn
欢迎 加入 零售创新 知识星球,知识星球主要以数据分析、报告分享、数据工具讨论为主;
1、价值上万元的专业的PPT报告模板。
2、专业案例分析和解读笔记。
3、实用的Excel、Word、PPT技巧。
4、VIP讨论群,共享资源。
5、优惠的会员商品。
6、一次付费只需99元,即可下载本站文章涉及的文件和软件。
共有 0 条评论