0

0

C# 操作字幕文件 C#如何解析和创建SRT或VTT格式的字幕

煙雲

煙雲

发布时间:2026-02-17 08:29:02

|

320人浏览过

|

来源于php中文网

原创

srt/vtt字幕解析与生成需手动处理时间戳、跳过非字幕行、使用crlf+utf-8 bom编码、截断毫秒防浮点误差。

c# 操作字幕文件 c#如何解析和创建srt或vtt格式的字幕

解析 SRT 字幕时,时间戳格式不匹配就直接崩

常见错误是用 DateTime.Parse 直接转 "00:01:23,456",但 SRT 的毫秒分隔符是逗号,而 .NET 默认认点号;更糟的是有些文件用分号(老版规范),或缺前导零。一解析就抛 FormatException

正确做法是手写解析逻辑,别依赖通用时间解析:

  • string.Split 拆开 "-->" 两边,再对每段按 ":"","";" 分割
  • 小时、分钟、秒转 int,毫秒部分用 int.TryParse(..., out var ms) 防逗号/分号混用
  • 构造 TimeSpannew TimeSpan(0, hours, minutes, seconds, ms),别碰 DateTime

示例片段:

var parts = line.Split(new[] { " --> " }, StringSplitOptions.None);
var startParts = Regex.Split(parts[0].Trim(), @"[:;,]");
// 然后逐段 int.TryParse

VTT 解析要小心头部的 WEBVTT 声明和注释行

很多人直接 File.ReadAllLines 后从第 0 行开始 parse,结果把 WEBVTT、空行、NOTE 行当成了字幕块,导致索引错乱、ID 错位。

VTT 是有明确起始标识的文本格式,必须跳过非字幕内容:

  • 逐行读,遇到第一个符合 ^\d+$ 的行才开始当作序号(可选),下一行才是时间轴
  • 时间轴行必须含 --> 且前后都有有效时间格式,否则跳过
  • 字幕正文以空行结束;遇到新序号或 EOF 才收尾当前条目
  • 别假设每条都带序号——VTT 允许省略,SRT 则强制有

生成 SRT/VTT 时,换行和编码不处理好,播放器直接拒载

Windows 记事本打开正常,PotPlayer/VLC 却显示乱码或只读第一行?大概率是用了 \n 换行 + UTF-8 无 BOM。SRT/VTT 规范要求 CRLF(\r\n),且多数播放器(尤其旧版)只认 UTF-8 with BOM。

360智绘
360智绘

360智脑推出的AI绘画创作与分享平台

下载

写文件时两个关键点不能漏:

  • Encoding.UTF8.GetBytes + File.WriteAllBytes,或指定 new StreamWriter(path, false, new UTF8Encoding(true))true 表示带 BOM)
  • 每行结尾必须是 "\r\n",别用 Environment.NewLine——它在 Linux/macOS 是 \n,会坏掉
  • SRT 序号后必须跟 \r\n,时间行后也必须跟 \r\n,字幕正文末尾不能多一个空行

时间精度差异会让字幕快进或延迟几帧

SRT 只支持毫秒(三位),VTT 支持毫秒甚至微秒(但实际只取三位)。如果你从视频帧时间(比如 23.976 fps 下的 TimeSpan.FromTicks)直接 ToString() 写入,可能生成 00:01:23.456789 这种非法格式,部分播放器截断、部分报错。

统一做截断处理:

  • 提取总毫秒数:(int)timeSpan.TotalMilliseconds % 1000
  • 避免四舍五入——字幕对齐靠的是向下取整,否则 999.8ms 会进到下一秒,造成跳断
  • VTT 中时间推荐用 hh:mm:ss.fff 格式输出,SRT 同理,但分隔符用 ,

真正麻烦的是跨格式转换:SRT 转 VTT 时,别把 ,456 直接换成 .456 就完事,得确认原始时间源有没有被 double 转换污染过——浮点误差叠一次就偏 1~2ms,连播 10 分钟可能偏半秒。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

750

2023.08.02

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

750

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

571

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

234

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

209

2025.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

234

2025.08.29

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

105

2025.10.23

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1136

2023.07.26

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

283

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 9.6万人学习

C 教程
C 教程

共75课时 | 4.8万人学习

C++教程
C++教程

共115课时 | 18.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号