首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用JS将milliSeconds转换为SRT时间

使用JS将milliSeconds转换为SRT时间
EN

Stack Overflow用户
提问于 2017-10-21 15:35:17
回答 3查看 1.7K关注 0票数 2

我有这样的输入:

代码语言:javascript
复制
start: 0.21 | duration: 0.30 | text: Subtitle Text 1 
start: 0.32 | duration: 0.52 | text: Subtitle Text 2 

需要将此输入转换为SRT格式,因此它变成如下所示:

代码语言:javascript
复制
1
00:00:00,210 --> 00:00:00,300
Subtitle Text 1

2
00:00:00,320 --> 00:00:00,520
Subtitle Text 2

联署材料:

代码语言:javascript
复制
function formatMilliseconds($milliseconds) {
    $seconds = Math.floor($milliseconds / 1000);
    $minutes = Math.floor($seconds / 60);
    $hours = Math.floor($minutes / 60);
    $milliseconds = $milliseconds % 1000;
    $seconds = $seconds % 60;
    $minutes = $minutes % 60;
console.log( $hours, $minutes, $seconds, $milliseconds); // 0 0 0 0.21

}

formatMilliseconds(0.21)

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2017-10-21 16:29:20

首先,您需要将输入格式转换为可处理的格式,类似于

代码语言:javascript
复制
var subtitles = [
{
  start: 0.21,
  end: 0.3,
  text: "Subtitle Text 1"
},
{
  start: 0.32,
  end: 0.52,
  text: "Subtitle Text 2"
}
];

请注意,我在这里选择“结束”而不是“持续时间”,因为在我看来,“持续时间”意味着字幕以开始+持续时间结束(0.21 + 0.3 = 0.51)秒。

格式化函数几乎是正确的,但需要以毫秒形式提供输入值,而不是十进制秒值。对于输出,还需要使用零填充小时/分钟/秒。您最好使用帮助函数来指定目标字符串长度,但在本例中,我只是内联地这样做:

代码语言:javascript
复制
var subtitles = [
    {
      start: 0.21,
      end: 0.3,
      text: "Subtitle Text 1"
    },
    {
      start: 0.32,
      end: 0.52,
      text: "Subtitle Text 2"
    }
  ],
  srtCount = 0;

function srtTimestamp(seconds) {
    var $milliseconds = seconds*1000;
    
    $seconds = Math.floor($milliseconds / 1000);
    $minutes = Math.floor($seconds / 60);
    $hours = Math.floor($minutes / 60);
    $milliseconds = $milliseconds % 1000;
    $seconds = $seconds % 60;
    $minutes = $minutes % 60;
    return ($hours < 10 ? '0' : '') + $hours + ':'
         + ($minutes < 10 ? '0' : '') + $minutes + ':'
         + ($seconds < 10 ? '0' : '') + $seconds + ','
         + ($milliseconds < 100 ? '0' : '') + ($milliseconds < 10 ? '0' : '') + $milliseconds;
}

function inputToSRT(sub_in) {
  return ++srtCount + "\r\n" + srtTimestamp(sub_in.start) + " --> " + srtTimestamp(sub_in.end) + "\r\n" + sub_in.text + "\r\n\r\n";
}
  
for (var i=0; i<subtitles.length; i++) {
  console.log(inputToSRT(subtitles[i]));
}

票数 7
EN

Stack Overflow用户

发布于 2017-10-21 16:12:32

您可以使用moment.js (日期/时间操作)和斯普林特 (字符串格式)来实现这种转换。

代码语言:javascript
复制
var data = 'start: 0.21 | duration: 0.30 | text: Subtitle Text 1' + '\n' +
    'start: 0.32 | duration: 0.52 | text: Subtitle Text 2';

function formatSrt(data) {
    var lines = data.split('\n');
    var result = [];
    var formatTime = function (value) {
        if (typeof value === 'string') {
            value = parseFloat(value);
            if (isNaN(value)) {
                throw new Exception('Invalid time "' + value + '"');
            }
        }
        var d = moment.duration(value * 1000, 'ms');
        return sprintf('%02d:%02d:%02d,%03d', d.get('h'), d.get('m'), d.get('s'), d.get('ms'));
    }
    lines.forEach(function (line, index) {
        result.push(index + 1);
        var parts = line.split('|');
        var start = formatTime(parts.shift().split(':').pop().trim());
        var end = formatTime(parts.shift().split(':').pop().trim());
        var comment = parts.shift().split(':').pop().trim();
        result.push(sprintf('%s --> %s', start, end));
        result.push(comment);
        result.push('');
    })
    return result.join('\n');
}

console.log(formatSrt(data));
代码语言:javascript
复制
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.19.1/moment.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/sprintf/1.1.1/sprintf.min.js"></script>

票数 1
EN

Stack Overflow用户

发布于 2017-10-21 16:21:44

这是我的尝试,可以改进,但它是有效的。

可以在这里测试:https://jsfiddle.net/gugp6psb/5/

代码语言:javascript
复制
function toSrt(input) {
    var srtOutput = '';
    // Each line will contain the following input start: 0.21 | duration: 0.30 | text: Subtitle Text 1
    var items = input.split('\n');
    for(var i = 0; i < items.length; i++){
        var item = items[i]; 

        // Split each element using | as the separator
        var inputElements = item.split("|");

        // Remove unnecesary text, format numbers
        var start = parseFloat(inputElements[0].replace('start:', '').replace(' ',''));
        var duration = parseFloat(inputElements[1].replace('duration:', '').replace(' ',''));
        var text = inputElements[2].replace('text:','');

        var srt = (i + 1) + '\n';
        srt += formatMilliseconds(start * 1000) + ' --> ' + formatMilliseconds(duration * 1000) + '\n';
        srt += text;

        if (i > 0)
            srtOutput += '\n';

        srtOutput += srt;
    }

    return srtOutput;
}

function formatMilliseconds(milliseconds) {
    var seconds = Math.floor(milliseconds / 1000) % 60;
    var minutes = Math.floor(seconds / 60)  % 60;
    var hours = Math.floor(minutes / 60);
    var milliseconds = milliseconds % 1000;

    return pad(hours) + ':' + pad(minutes) + ':' + pad(seconds) + ',' + pad(milliseconds);
}

function pad(n) {
    return (n < 10) ? ("0" + n) : n;
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46864913

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档