网络下载ts流媒体

网络下载ts流媒体

    • 查看
    • 下载
    • 排序
    • 合并

很多视频网站,尤其是微信小程序中的长视频无法获取到准确视频地址,只能抓取到.ts片段地址,下载后发现基本都是5~8秒时长。
例如:
获取到的片段地址
我们需要将以上地址片段全部下载后排序后再合成新的长视频。

查看

在此界面右键copy --> copy all list URLs 并将结果放入到一个list.txt中
例如:
list.txt

下载

将片段全部下载到ts文件夹内

import os
import requests
from urllib.parse import urlparse

# 创建ts文件夹(如果不存在)
if not os.path.exists('ts'):
    os.makedirs('ts')

# 读取list.txt文件
with open('list.txt', 'r') as file:
    urls = file.readlines()

# 处理每个URL
for url in urls:
    url = url.strip()  # 移除换行符和空格
    if url:
        try:
            # 从URL中获取文件名
            filename = os.path.basename(urlparse(url).path)
            if not filename.endswith('.ts'):
                filename += '.ts'
            
            # 下载文件
            response = requests.get(url, stream=True)
            response.raise_for_status()  # 检查是否成功获取
            
            # 保存文件
            filepath = os.path.join('ts', filename)
            with open(filepath, 'wb') as f:
                for chunk in response.iter_content(chunk_size=8192):
                    if chunk:
                        f.write(chunk)
            
            print(f'成功下载: {filename}')
            
        except Exception as e:
            print(f'下载失败 {url}: {str(e)}')

print('所有下载���成!')

排序

对下载后的片段名称排序,一般序列数值在名称中。
例如:4261649925_937121059_2632.ts 其中的2632就是片段序列,当然不是所有序列都是最后一个数,这个要自己分析,按照分析后的点击查看两个下载好的片段就可以了。这个给个针对此命名规则的重命名代码。

import os


def get_number_after_second_underscore(filename):
    # 分割文件名,获取第二个下划线后的数字
    try:
        parts = filename.split('_')
        if len(parts) >= 3:
            # 获取最后一部分并移除可能的.ts后缀
            last_part = parts[2].replace('.ts', '')
            return int(last_part)
    except (IndexError, ValueError):
        return None
    return None


# 获取ts文件夹中的所有ts文件
ts_folder = 'ts'
ts_files = [f for f in os.listdir(ts_folder) if f.endswith('.ts')]

# 重命名文件
for filename in ts_files:
    print(filename)
    number = get_number_after_second_underscore(filename)
    print(number)
    if number is not None:
        # 构建新文件名
        new_filename = f"{number:03d}.ts"  # 使用3位数字格式,例如:001.ts

        # 构建完整的文件路径
        old_path = os.path.join(ts_folder, filename)
        new_path = os.path.join(ts_folder, new_filename)

        try:
            os.rename(old_path, new_path)
            print(f'已重命名: {filename} -> {new_filename}')
        except Exception as e:
            print(f'重命名失败 {filename}: {str(e)}')

print('重命名完成!')

合并

将排序好的视频片段合并,需要预先安装ffmpeg

import os
import subprocess




# 获取ts文件夹中的所有ts文件
ts_folder = 'ts'
ts_files = [f for f in os.listdir(ts_folder) if f.endswith('.ts')]

# # 使用自定义排序
# ts_files.sort(key=get_sort_key)

print('文件排序完成,开始合并...')
print(f'共找到 {len(ts_files)} 个ts文件')

# 方法1:使用ffmpeg合并(推荐)
try:
    # 创建临时文件列表
    with open('filelist.txt', 'w', encoding='utf-8') as f:
        for ts_file in ts_files:
            f.write(f"file 'ts/{ts_file}'\n")

    # 使用ffmpeg合并
    print('正在合并文件...')
    subprocess.run([
        'ffmpeg',
        '-f', 'concat',
        '-safe', '0',
        '-i', 'filelist.txt',
        '-c', 'copy',
        'output.mp4'
    ], check=True)

    print('合并完成!输出文件:output.mp4')

    # 清理临时文件
    os.remove('filelist.txt')

except FileNotFoundError:
    print('错误:找不到ffmpeg,尝试使用备用方法合并...')

    # 方法2:直接合并(备用方法)
    try:
        with open('output.mp4', 'wb') as outfile:
            for ts_file in ts_files:
                print(f'正在处理: {ts_file}')
                with open(os.path.join(ts_folder, ts_file), 'rb') as infile:
                    outfile.write(infile.read())
        print('使用备用方法合并完成!输出文件:output.mp4')

    except Exception as e:
        print(f'合并失败: {str(e)}')

except Exception as e:
    print(f'合并失败: {str(e)}')

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/942747.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

小程序租赁系统开发指南与实现策略

内容概要 在如今这个快节奏的时代,小程序租赁系统的开发正逐渐成为许多商家提升服务质量与效率的重要选择。在设计这样一个系统时,首先要明白它的核心目标:便捷、安全。用户希望在最短的时间内找到需要的物品,而商家则希望通过这…

机器人C++开源库The Robotics Library (RL)使用手册(一)

强大的、完整的C机器人开源库 1、是否可以免费商用?2、支持什么平台?3、下载地址4、开始! 1、是否可以免费商用? Robotics Library(RL)是一个独立的C库,用于机器人运动学、运动规划和控制。它涵…

Android unitTest 单元测试用例编写(初始)

文章目录 了解测试相关库导入依赖库新建测试文件示例执行查看结果网页结果其他 本片讲解的重点是unitTest,而不是androidTest哦 了解测试相关库 androidx.compose.ui:ui-test-junit4: 用于Compose UI的JUnit 4测试库。 它提供了测试Compose UI组件的工具和API。 and…

Ngnix介绍、安装、实战及用法!!!

一、Nginx简介 1、Nginx概述 Nginx (“engine x”) 是一个高性能的 HTTP 和 反向代理服务器,特点是占有内存少,并发能力强,能经受高负载的考验,有报告表明能支持高达 50,000 个并发连接数 。 2、正向代理 正向代理:如果把局…

国内智能编程助手简易对比:文心一言、通义千问、智谱AI、讯飞星火、Kimi

最近想给IDE选择一个智能编程助手插件,但鉴于国内百花齐放的现状,一时也不好选择用哪个。挑了几个主流的的平台,分别输入“用python实现雪花纷飞的场景”的简单需求,看看效果对比。备注:因国外插件使用成本远高于国内的…

vscode python pip : 无法将“pip”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。()

问题: PS C:\Users\EDY\Desktop\vscodeTest> pip pip : 无法将“pip”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保 路径正确,然后再试一次。 所在位置 行:1 字符: 1 pip …

vue3封装而成的APP ,在版本更新后,页面显示空白

一、问题展示 更新之后页面空白,打不开 ,主要是由于缓存造成的 二、解决办法 1、随机数代码实现 使用随机数来动态的生成静态资源目录名可以避免浏览器缓存,但同时每次也会导致浏览器每次都下载最新的资源。如果静态资源过大,可…

HarmonyOS NEXT 实战之元服务:静态多案例效果(一)

背景: 前几篇学习了元服务,后面几期就让我们开发简单的元服务吧,里面丰富的内容大家自己加,本期案例 仅供参考 先上本期效果图 ,里面图片自行替换 效果图1代码案例如下: import { authentication } from…

SpringAI人工智能开发框架006---SpringAI多模态接口_编程测试springai多模态接口支持

可以看到springai对多模态的支持. 同样去创建一个项目 也是跟之前的项目一样,修改版本1.0.0 这里 然后修改仓库地址,为springai的地址 然后开始写代码

基础运维学习计划-base版

目录 需要学习的内容? liunx基础 sql/mysql基础 tcp/ip协议基础 http基础 dns基础 网络基础:交换&路由概念&原理 常见网络协议 月学习计划 12.26 日 (bilibili自己找视频看看,资源很多) 12.27日 1…

2、C#基于.net framework的应用开发实战编程 - 设计(二、三) - 编程手把手系列文章...

二、设计; 二.三、构建数据库; 此例子使用的是SQLite数据库,所以数据库工具用的SQLiteStudio x64,这个是SQLite专用的数据库设计管理工具,其它的数据库管理工具比如DBeaver的使用请见实战工具系列文章。 1、…

shardingsphere分库分表项目实践1-让shardingsphere运行起来

学习新技术最快的方式就是: 1. 先找一个比较完善的demo跑起来 2. 弄清楚用法:配置、原理、使用场景 3. 移植到自己项目上,按照自己需求进行修改优化。 找demo项目的方法:优先去官方git库找,如果没有或者过于简单那么…

【运维笔记】windows 11 中提示:无法成功完成操作,因为文件包含病毒或潜在的垃圾软件。

项目场景: 提示:向日葵远程给客户安装数据库管理软件Navicat 15,提示文件被清理: 原因分析: 提示:可能是文件含有病毒,或者是Windows认为我们下载的软件有病毒,还有就是开发过程做…

使用开源在线聊天工具Fiora轻松搭建个性化聊天平台在线交流

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家:人工智能教程 文章目录 前言1.关于Fiora2.安装Docker3.本地部署Fiora4.使用Fiora5.cpolar内网穿透工具安装6.创建远程连接公网地址7.固定Uptime …

【C#联合halcon实现绘制ROI功能】

前言 C#联合halcon实现绘制ROI功能: C#联合Halcon,使用HDrawingObject、HDrawingObjectXld,绘制矩形、方向矩形、圆形、椭圆、自定义ROI。支持拖动、重设大小、选中。 运行结果 代码 代码结构 MainForm 视图 MainViewModel 视图模型 ROI R…

Visual Studio 使用 GitHub Copilot 与 IntelliCode 辅助编码 【AI辅助开发系列】

🎀🎀🎀【AI辅助编程系列】🎀🎀🎀 Visual Studio 使用 GitHub Copilot 与 IntelliCode 辅助编码Visual Studio 安装和管理 GitHub CopilotVisual Studio 使用 GitHub Copilot 扩展Visual Studio 使用 GitHu…

4.FPGA如何实现设计

在前面分别引入了,LUT的知识,全局时钟网络,以及FPGA内部的资源。 LUT的知识: 在FPGA设计中实现的逻辑运算在不借用其他的硬核的基础上都是在LUT中通过查表的方式进行完成的,比如实现的c a & b;就是将a&b的所…

centos权限大集合,覆盖多种权限类型,解惑权限后有“. + t s”问题!

在 CentOS 系统中,权限管理是操作系统的核心功能之一,确保不同用户和进程对文件、目录以及设备的访问被合理控制。 权限系统主要包括传统的 Unix 权限模型、特殊权限(SetUID、SetGID、Sticky 位)和更精细的访问控制列表&#xff…

不良人系列-复兴数据结构(栈和队列)

个人主页:爱编程的小新☆ 不良人经典语录:“相呴相济 玉汝于成 勿念 心安” 目录 一. 栈(stack) 1. 栈的概念 2. 栈的常见方法 3.栈的模拟实现 ​编辑 二. 队列 1. 队列的概念 2. 队列的使用 2.1 队列的常见方法 2.2 队列的模拟实现 2.3 队列…

【动态规划篇】步步带你深入解答成功AC最优包含问题(通俗易懂版)

本篇小鸡汤:待到苦尽甘来时,我给你讲讲来时路。 欢迎拜访:羑悻的小杀马特.-CSDN博客 本篇主题:解答洛谷的最优包含问题 制作日期:2024.12.23 隶属专栏:C/C题海汇总 ​​ 目录 本篇简介: 一动态…