网络下载ts流媒体

news2025/2/26 14:24:55

网络下载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)}')

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

(叁)前端实现加密的方式:AES 加密(实现的两种方式)

前端实现加密: Ⅰ、AES 加密:1、使用 AES 加密前的准备工作:其一、安装 crypto-js :A、安装命令:B、成功安装后的截图: 2、实现 AES 加密的方式一:其一、在项目中创建 crypto.js 文件&#xff1…

kubernates实战

使用k8s来部署tomcat 1、创建一个部署,并指定镜像地址 kubectl create deployment tomcat6 --imagetomcat:6.0.53-jre82、查看部署pod状态 kubectl get pods # 获取default名称空间下的pods kubectl get pods --all-namespaces # 获取所有名称空间下的pods kubect…

自动化测试框架playwright 常见问题和解决方案

自动化课程已经讲完了playwright框架,很多同学跃跃欲试,所谓实践出真知,这不在实践中就要到了一些问题,小编也给大家整理出来了,送个有需要的同学,记得点赞收藏哦~~ 01安装问题 问题描述: 在安…

清华、智谱团队:探索 RLHF 的 scaling laws

基于人类反馈的强化学习(RLHF)是优化大语言模型(LLM)行为的关键技术,能够让模型更符合人类偏好和需求,提升生成质量。 然而,目前关于 RLHF 的 scaling(扩展)潜力研究仍然…

八股(One Day one)

最近老是看到一些面试的视频,对于视频内部面试所提到的八股文,感觉是知道是什么,但是要说的话,却又不知道该怎么说(要不咋称之为八股文呢),所以就想到写一篇八股文总结的博客,以便进…

springboot创建web项目

一、创建项目 二、导入依赖&#xff08;pom.xml&#xff09; <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schem…

LeetCode 343.整数拆分

1.题目要求: 2.题目代码: class Solution { public:int integerBreak(int n) {//先确定dp数组vector<int> dp;//1.确定dp数组的含义//2.确定dp的递推公式//3.初始化dp数组//4.遍历顺序dp.resize(n 1);dp[0] 0;dp[1] 0;dp[2] 1;for(int i 3;i < n;i){for(int j …

Postman最新详细安装及使用教程【附安装包】

一、Postman介绍 ‌Postman是一个功能强大的API测试工具&#xff0c;主要用于模拟和测试各种HTTP请求&#xff0c;支持GET、POST、PUT、DELETE等多种请求方法。‌通过Postman&#xff0c;用户可以发送请求并查看返回的响应&#xff0c;检查响应的内容和状态&#xff0c;从而验…

开源 JS PDF 库比较

原文查看&#xff1a;开源JavaScript PDF Library对比 对于需要高性能、复杂功能或强大支持处理复杂 PDF 的项目&#xff0c;建议选择商业​​ PDF 库, 如ComPDFKit for Web。但是&#xff0c;如果您的目标只是在 Web 应用程序中显示 PDF&#xff0c;则可以使用几个可靠的开源…

如何利用AWS监听存储桶并上传到tg bot

业务描述&#xff1a; 需要监听aws的存储中的最新消息&#xff0c;发送新的消息推送到指定tg的频道。 主要流程&#xff1a; 1.上传消息到s3存储桶&#xff08;不做具体描述&#xff09; 2.通过aws的lambda监听s3存储桶的最新消息&#xff08;txt文件&#xff09; 3.将txt文件…

数据结构:双向循坏链表

目录 1.1双向循环链表的结构 2.双向链表功能的实现 2.1初始化链表 2.2销毁链表 2.3创建结点 2.4打印链表 2.5链表查找 2.6链表在pos的前面进行插入 2.7链表删除pos位置的节点 2.8链表的头插&#xff0c;头删 &#xff0c;尾插&#xff0c;尾删 1.1双向循环链表的结构 …

大数据技术原理与应用期末复习-代码

RDD&#xff1a; // 导入SparkConf和SparkContext类&#xff0c;用于配置和创建Spark上下文 import org.apache.spark.{SparkConf, SparkContext}// 定义一个名为TopN的对象 object TopN {def main(args: Array[String]): Unit {// 创建一个新的SparkConf对象&#xff0c;并设…

CNN和Transfomer介绍

文章目录 CNN和Transfomer介绍CNN和Transfomer的区别1. **基本概念**2. **数据处理方式**3. **模型结构差异**4. **应用场景区别** 自注意力机制1. **自注意力机制的概念**2. **自注意力机制的实现步骤**3. **自注意力机制的优势** Transformer结构组成1. **多头注意力层&#…

ArcGIS Pro 3.4新功能3:空间统计新特性,基于森林和增强分类与回归,过滤空间自相关

目录 应用 1&#xff1a;它是相关性还是托布勒第一定律&#xff1f; 应用 2&#xff1a;将空间带入非空间模型 结论 在 ArcGIS Pro 3.4 中&#xff0c;我们在新的空间组件实用程序&#xff08;Moran 特征向量&#xff09;工具集中发布了一个新工具 - 从字段过滤空间自相关。…

webserver log日志系统的实现

参考博客&#xff1a;https://blog.csdn.net/weixin_51322383/article/details/130474753 https://zhuanlan.zhihu.com/p/721880618 阻塞队列blockqueue 1、阻塞队列的设计流程是什么样的 它的底层是用deque进行管理的 阻塞队列主要是围绕着生产者消费者模式进行多线程的同步和…

深度学习实战之超分辨率算法(tensorflow)——ESPCN

espcn原理算法请参考上一篇论文&#xff0c;这里主要给实现。 数据集如下&#xff1a;尺寸相等即可 针对数据集&#xff0c;生成样本代码preeate_data.py import imageio from scipy import misc, ndimage import numpy as np import imghdr import shutil import os import…

Unity3d 基于UGUI和VideoPlayer 实现一个多功能视频播放器功能(含源码)

前言 随着Unity3d引擎在数字沙盘、智慧工厂、数字孪生等场景的广泛应用&#xff0c;视频已成为系统程序中展示时&#xff0c;不可或缺的一部分。在 Unity3d 中&#xff0c;我们可以通过强大的 VideoPlayer 组件和灵活的 UGUI 系统&#xff0c;将视频播放功能无缝集成到用户界面…

WebGAL 项目下载及安装教程

WebGAL 项目下载及安装教程 WebGAL A brand new web Visual Novel engine | 全新的网页端视觉小说引擎 [这里是图片001] 项目地址: https://gitcode.com/gh_mirrors/web/WebGAL 1、项目介绍 WebGAL 是一个全新的网页端视觉小说引擎&#xff0c;旨在提供美观、功能强大且易于…

虚幻引擎是什么?

Unreal Engine&#xff0c;是一款由Epic Games开发的游戏引擎。该引擎主要是为了开发第一人称射击游戏而设计&#xff0c;但现在已经被成功地应用于开发模拟游戏、恐怖游戏、角色扮演游戏等多种不同类型的游戏。虚幻引擎除了被用于开发游戏&#xff0c;现在也用于电影的虚拟制片…

Kubernetes 架构图和组件

&#x1f9d1; 博主简介&#xff1a;CSDN博客专家&#xff0c;历代文学网&#xff08;PC端可以访问&#xff1a;历代文学&#xff0c;移动端可微信小程序搜索“历代文学”&#xff09;总架构师&#xff0c;15年工作经验&#xff0c;精通Java编程&#xff0c;高并发设计&#xf…