Python+ffmpeg实现字幕视频合并

ops/2024/10/10 22:58:36/

背景

我想给自己的视频添加字幕,但是市面上比较好的软件都不太对我口味,要么贵,要么就是学习版不给力。兜兜转转,我决定用多款开源软件分步实现,当然,也可以去白piao某些软件的字幕功能。

驱动力

ffmpeg -i video.mp4 -vf subtitles=srt_file.srt output.mp4

d6bebf4be0064ef4be71d80607988284.png

成果

于是我写了一个脚本 

python">import osdef start_question():print('\033[38;2;0;255;0m' + '请确认已下载ffmpeg,并已将其的bin文件夹添加至环境变量' + '\033[0m')print("您可以在此获取 https://www.gyan.dev/ffmpeg/builds/")confirm1 = input("Y/N?[Y]")if confirm1 == "N":input("[回车退出]")return Falseprint('\033[38;2;0;255;0m' + '请确认您已知晓本程序的基本原理:' + '\033[0m')print('\033[38;2;255;0;0m' + 'ffmpeg -i video.mp4 -vf subtitles=srt_file.srt output.mp4' + '\033[0m')confirm2 = input("Y/N?[Y]")if confirm2 == "N":input("[回车退出]")return Falsereturn Truedef out_mp4_file():print("您可以使用相对路径,三条路径均不能包含中文字符!")mp4_file = input('\033[36m' + "请输入mp4文件路径:" + '\033[0m')srt_file = input('\033[36m' + "请输入srt文件路径:" + '\033[0m')out_file = input('\033[36m' + "请输入输出文件路径:" + '\033[0m')if mp4_file and srt_file and out_file:os.system("ffmpeg -i {0} -vf subtitles={1} {2}".format(mp4_file, srt_file, out_file))else:print('\033[38;2;255;0;0m' + "您的输入好像有问题,请检查后再试" + '\033[0m')flag = Falsewhile True:if not flag:flag = start_question()if not flag:breakout_mp4_file()confirm3 = input("[回车继续/q 退出]")if confirm3 == "q":break

值得注意的是,字幕文件要自己写好,要能对应的上视频,至于对应不上的,没有尝试过。

 核心是这个:

python">os.system("ffmpeg -i {0} -vf subtitles={1} {2}".format(mp4_file, srt_file, out_file))

运行结果

毫无疑问失败了,不过错误也很经典——千万不要在路径中带有中文字符!

输出时会显示视频和字幕详情(命令行)。

当然,这种脚本是不可能为字幕添加特效的,要专门的剪辑软件才行。

 

 

 


http://www.ppmy.cn/ops/123687.html

相关文章

米哈游Android面试题汇总及参考答案

Java 的内存回收机制是如何工作的? 在 Java 中,内存回收主要由垃圾回收器(Garbage Collector)来完成。 Java 的内存主要分为堆(Heap)和栈(Stack)等区域。其中,对象主要分配在堆上。当创建一个对象时,会在堆上为其分配内存空间。 垃圾回收器主要负责回收不再被使用的对…

146. LRU 缓存【 力扣(LeetCode) 】

零、原题链接 146. LRU 缓存 一、题目描述 请你设计并实现一个满足 LRU (最近最少使用) 缓存 约束的数据结构。 实现 LRUCache 类: LRUCache(int capacity) 以 正整数 作为容量 capacity 初始化 LRU 缓存int get(int key) 如果关键字 key 存在于缓存中&#xff…

穷人就不该乱买电车

文 | AUTO芯球 作者 | 雷慢 买车最怕的是什么你知道吗? 是没钱的穷人还要去买豪华电车, 比买电车更可怕的是什么你知道吗? 是买了电车没两年又卖了! 真不是讲鬼故事, 新能源车尤其是纯电车,一年打五折…

掌握 C# 中的 LINQ(语言集成查询)

LINQ(Language Integrated Query,语言集成查询)是 C# 中的一项强大功能,它使得我们能够使用查询语法处理不同的数据源,如对象、XML、数据库等。LINQ 通过提供统一的查询语法,使开发者能够更加简洁、高效地操…

设计模式之---工厂模式

设计模式–工厂模式 一 什么是工厂模式 使用工厂模式是为了将创建对象的具体过程屏蔽隔离起来 快速的将对象实例化 从而提高了代码的灵活性和改善了简洁性,工厂模式具体分为以下三类: 1 简单工厂模式(Simple Factory) 2 工厂方…

古典舞在线交流平台:SpringBoot设计与实现详解

摘 要 随着互联网技术的发展,各类网站应运而生,网站具有新颖、展现全面的特点。因此,为了满足用户古典舞在线交流的需求,特开发了本古典舞在线交流平台。 本古典舞在线交流平台应用Java技术,MYSQL数据库存储数据&#…

CoroutineWorker 压缩图片示例

CoroutineWorker 的主要特点: Kotlin 协程支持:通过使用 Kotlin 协程,CoroutineWorker 提供了更自然和可读的异步编程模型,避免了复杂的回调嵌套问题。 后台任务:它允许开发者在后台执行任务,比如数据同步…

CentOS 6文件系统

由冯诺依曼在 1945 年提出的计算机五大组成部分:运算器,控制器,存储器,输入设 备,输出设备。 1. 硬盘结构: (1)机械硬盘结构: 磁盘拆解图: 扇区,…