Python结合FFmpeg实现将MP4视频与SRT字幕无损合并

 更新时间:2026年01月19日 09:07:47   作者:weixin_46244623  
在日常视频处理场景中,我们经常需要将字幕(SRT)合并到视频中,本文将介绍如何使用 Python 调用 FFmpeg将 MP4 视频与 SRT 字幕无损合并为一个新视频文件,感兴趣的小伙伴可以了解下

在日常视频处理场景中,我们经常需要将字幕(SRT)合并到视频中,尤其是从 B 站等平台下载的视频,字幕通常是单独的 .srt 文件。

本文将介绍一种稳定、可复用、支持中文编码的方案:使用 Python 调用 FFmpeg,将 MP4 视频与 SRT 字幕无损合并为一个新视频文件。

一、实现目标

  • 合并 MP4 视频 + SRT 字幕
  • 不重新编码视频 / 音频(速度快、无损)
  • 正确处理 UTF-8 中文字幕
  • 设置字幕语言元数据(如 chi
  • 封装为可复用的 Python 函数

二、环境准备

安装 FFmpeg

Ubuntu / Debian

sudo apt install ffmpeg

macOS(Homebrew)

brew install ffmpeg

Windows

下载解压后将 ffmpeg.exe 加入系统 PATH

验证是否安装成功:

ffmpeg -version

Python 环境

  • Python 3.7+
  • 无需额外第三方库(只使用标准库)

三、核心思路说明

我们要做的事情本质上就是执行下面这条 FFmpeg 命令:

ffmpeg -sub_charenc UTF-8 \
-i input.mp4 \
-i subtitle.srt \
-c:v copy \
-c:a copy \
-c:s mov_text \
-metadata:s:s:0 language=chi \
output.mp4

关键点解释:

参数作用
-sub_charenc UTF-8强制字幕编码为 UTF-8(防止中文乱码)
-c:v copy视频流不重新编码
-c:a copy音频流不重新编码
-c:s mov_textMP4 容器支持的字幕编码
language=chi设置字幕语言为中文

四、完整 Python 实现代码

import subprocess
import os
import sys

def validate_file(file_path, file_type="file"):
    """
    校验文件是否存在
    :param file_path: 文件路径
    :param file_type: 文件类型描述(用于错误提示)
    """
    if not os.path.exists(file_path):
        raise FileNotFoundError(f"{file_type} 不存在: {file_path}")
    print(f"{file_type} 校验通过: {file_path}")
    return True


def merge_video_with_subtitles(video_path, srt_path, output_path):
    """
    使用 FFmpeg 将 MP4 视频与 SRT 字幕合并
    不重新编码视频和音频,支持 UTF-8 中文字幕
    """

    # 1. 校验输入文件是否存在
    validate_file(video_path, "视频文件")
    validate_file(srt_path, "字幕文件")

    # 2. 构建 FFmpeg 命令
    ffmpeg_cmd = [
        "ffmpeg",

        # 输入视频文件
        "-i", video_path,

        # 输入字幕文件
        "-i", srt_path,

        # 视频流直接拷贝,不重新编码
        "-c:v", "copy",

        # 音频流直接拷贝,不重新编码
        "-c:a", "copy",

        # 将 SRT 转换为 MP4 支持的 mov_text 字幕格式
        "-c:s", "mov_text",

        # 设置字幕语言元数据为中文
        "-metadata:s:s:0", "language=chi",

        # 输出文件
        output_path
    ]

    # 3. 强制指定字幕编码为 UTF-8,防止中文乱码
    ffmpeg_cmd.insert(3, "-sub_charenc")
    ffmpeg_cmd.insert(4, "UTF-8")

    try:
        # 4. 执行 FFmpeg 命令
        result = subprocess.run(
            ffmpeg_cmd,
            check=True,
            stdout=subprocess.PIPE,
            stderr=subprocess.PIPE,
            text=True
        )
        print(f"字幕合并成功,输出文件: {output_path}")

    except subprocess.CalledProcessError as e:
        # FFmpeg 执行失败时输出错误信息
        print("FFmpeg 执行失败:")
        print(e.stderr)
        raise

    except Exception as e:
        # 其他异常
        print(f"执行过程中发生错误: {e}")
        raise


def main():
    """
    主函数,定义输入输出路径
    """

    # 视频文件路径
    video_path = r"SSYouTube.online_Gesture Drawing Practice _ 20 and 40 sec. poses_1080p.mp4"

    # 字幕文件路径
    srt_path = r"SSYouTube.online_Gesture Drawing Practice _ 20 and 40 sec. poses_1080p.srt"

    # 输出视频路径
    output_path = "output.mp4"

    # 合并视频与字幕
    merge_video_with_subtitles(video_path, srt_path, output_path)


if __name__ == "__main__":
    try:
        main()
    except Exception as e:
        print(f"程序异常退出: {e}")
        sys.exit(1)

五、代码结构解析

文件校验(防止低级错误)

validate_file(video_path, "video")
validate_file(srt_path, "subtitle")
  • 避免 FFmpeg 报错才发现文件不存在
  • 提前失败,错误更友好

为什么使用subprocess.run

优点:

  • 可控参数列表(避免 shell 注入)
  • 可捕获 stdout / stderr
  • 出错自动抛异常(check=True

为什么选择mov_text

  • MP4 容器 不支持直接嵌入 SRT
  • mov_text 是 MP4 官方支持的字幕格式
  • 各大播放器(VLC、QuickTime、手机)兼容性好

六、常见问题与解决方案

中文字幕乱码

一定要加:

-sub_charenc UTF-8

并确保 .srt 本身是 UTF-8 编码。

想把字幕“烧录”到画面中

那就不能用 -c:v copy,需要使用:

-vf subtitles=xxx.srt

这是 硬字幕,不可关闭,且会重新编码(速度慢)。

以上就是Python结合FFmpeg实现将MP4视频与SRT字幕无损合并的详细内容,更多关于Python FFmpeg视频字幕合并的资料请关注脚本之家其它相关文章!

相关文章

  • python字典的常用操作方法小结

    python字典的常用操作方法小结

    下面小编就为大家带来一篇python字典的常用操作方法小结。小编觉得挺不错的,现在分享给大家,也给大家做个参考,一起跟随小编过来看看吧
    2016-05-05
  • 进一步探究Python的装饰器的运用

    进一步探究Python的装饰器的运用

    这篇文章主要介绍了更为深入的Python的装饰器的运用,Python的装饰器是Python学习进阶当中的重要知识点,需要的朋友可以参考下
    2015-05-05
  • Python利用keras接口实现深度神经网络回归

    Python利用keras接口实现深度神经网络回归

    这篇文章主要为大家详细介绍了基于Python语言中TensorFlow的Keras接口,实现深度神经网络回归的方法。文中的示例代码讲解详细,感兴趣的可以了解一下
    2023-02-02
  • Python计算图片数据集的均值方差示例详解

    Python计算图片数据集的均值方差示例详解

    这篇文章主要为大家介绍了Python计算图片数据集的均值方差,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-05
  • PyTorch上实现卷积神经网络CNN的方法

    PyTorch上实现卷积神经网络CNN的方法

    本篇文章主要介绍了PyTorch上实现卷积神经网络CNN的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-04-04
  • 三个python爬虫项目实例代码

    三个python爬虫项目实例代码

    这篇文章主要介绍了三个python爬虫项目实例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12
  • 基于Python实现优雅的目录结构打印工具

    基于Python实现优雅的目录结构打印工具

    在软件开发,系统管理和日常工作中,我们经常需要查看和分析目录结构,本文我们将使用Python语言打造一个目录结构打印工具,有需要的小伙伴可以了解下
    2025-07-07
  • Tornado源码分析之HTTP服务请求解析

    Tornado源码分析之HTTP服务请求解析

    这篇文章主要为大家介绍了Tornado源码分析之HTTP服务请求解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • 关于python selenium 运行时弹出窗口问题

    关于python selenium 运行时弹出窗口问题

    最近在做一个网页代填项目,用到了python的selenium知识,经过了各种尝试与搜索最后终算是较完美的解决了,下面小编给大家带来了python selenium 运行时弹出窗口问题,感兴趣的朋友一起看看吧
    2021-11-11
  • Python3爬虫发送请求的知识点实例

    Python3爬虫发送请求的知识点实例

    在本篇文章里小编给大家分享的是一篇关于Python3爬虫发送请求的知识点实例,需要的朋友们可以学习下。
    2020-07-07

最新评论