LRC转SRT

最近看到一首很好的英文MTV原版,没又字幕,自己找字幕,只找到LRC,ffmpeg不支持LRC,网上在线转了SRT。

Subtitle Converter | Free tool | GoTranscript

然后用 ffmpeg 加字幕

javascript 复制代码
ffmpeg -i LoveMeLikeYouDo.mp4 -vf subtitles=LoveMeLikeYouDo.srt LoveMeLikeYouDo1.mp4

打开 LRC 和 SRT 都是纯文本,可以自己做一个。

javascript 复制代码
<html>
<head>
<meta charset="UTF-8">
<title>LRC转SRT</title>
</head>
<body>
LRC:<input id="file" type="file"> <button id="button_srt">SRT</button>
<script>
var file0, s='';
file.addEventListener('change', function(){ read(); });
button_srt.addEventListener('click', function(){ lrc2srt(); });

function read() {
	file0 = file.files[0];
	var reader = new FileReader();
    reader.readAsText(file0);
    reader.onload = function(e){
		s = reader.result;
	};    
}

function lrc2srt() {
    var s1='', time=[], st=[];
    var sl = s.split('\n');    
    for (i=0; i<sl.length; i++) {
        if (sl[i].indexOf(']') != -1) {
            var sl1 = sl[i].split(']');
            time.push(sl1[0].substring(sl1[0].indexOf('[') + 1));
            st.push(sl1[1].replace(/&#39;/g, "'"));                   
        }
    }
	
	//合并时间重复
	for (i=0; i<time.length; i++) {		
        if (i > 1 && i < time.length - 1 && time[i] == time[i+1]) {
            st[i-1] = st[i-1] + '\n' + st[i];	//错位合并上一句
			time.splice(i, 1);
			st.splice(i, 1);
		}
    }
    
    for (i=0; i<time.length; i++) {
		s1 = s1 + (i+1) + '\n';
        if (i < time.length - 1) {
			var time1 = '00:' + time[i];
			if (time1.indexOf('.') == -1)
				time1 = time1 + '.000';
			var time2 = '00:' + time[i+1];
			if (time2.indexOf('.') == -1)
				time2 = time2 + '.000';
            s1 = s1 + time1 + ' --> ' + time2 + '\n';
		} else {
			var time1 = '00:' + time[i];
			if (time1.indexOf('.') == -1)
				time1 = time1 + '.000';
			s1 = s1 + time1 + ' --> ' + time1 + '\n';
		}		
        s1 = s1 + st[i] + '\n\n';
    }
    
    var blob = new Blob([s1], { type:'text/plain,charset=UTF-8' });
    var url = URL.createObjectURL(blob);
    //查看
    //window.open(url);
    //下载
    var link = document.createElement('a');
    link.download = file0.name.substring(0,file0.name.indexOf('.')) + '.srt';
    link.href = url;
    link.click();
}
</script>
</body>
</html>

视频处理CPU满载,处理时长和视频时间一样长!

有些字幕还是没对上,需要对LRC或者SRT编辑。

相关推荐
这儿有一堆花2 小时前
前端三件套真的落后了吗?揭开现代 Web 开发的底层逻辑
前端·javascript·css·html5
.Cnn2 小时前
JavaScript 前端基础笔记(网页交互核心)
前端·javascript·笔记·交互
醉酒的李白、2 小时前
Vue3 组件通信本质:Props 下发,Emits 回传
前端·javascript·vue.js
小芝麻咿呀4 小时前
vue--面试题第一部分
前端·javascript·vue.js
nibabaoo4 小时前
前端开发攻略---H5页面手机获取摄像头权限回显出画面并且同步到PC页面
javascript·websocket·实时音视频·实时同步·录制
早起傻一天~G4 小时前
vue2+element-UI表格封装
javascript·vue.js·ui
这儿有一堆花5 小时前
深入解析 Video.js:现代 Web 视频播放的工程实践
前端·javascript·音视频
烤麻辣烫5 小时前
JS基础
开发语言·前端·javascript·学习
猫猫不是喵喵.7 小时前
layui表单项次大数据量导入并提交
前端·javascript·layui
Hello--_--World7 小时前
ES13:类私有属性和方法、顶层 await、at() 方法、Object.hasOwnProperty()、类静态块 相关知识点
开发语言·javascript·es13