我一直在尝试验证包含LRC文件的String http://en.wikipedia.org/wiki/LRC_%28file_format%29
并希望通过正则表达式,验证文件的格式是否正确。 它将是有效的,不仅仅是以[mm:ss.xx]开头的行,而且还有[mm:ss],因为它默认为xx = 00
因此,如果文件的更正与否,将会返回的想法,包括 也可能出现在文件中的ID标签。
提前致谢
答案 0 :(得分:0)
我想你需要循环遍历文件中的每一行并针对正则表达式进行测试,以检查它是否与语法匹配。如果正则表达式失败,那么你显然会返回false
。适当的正则表达式可能是这样的:
\[[0-9]{2}\:[0-9]{2}(\.[0-9]{2})?\]([\w:\s]+)
哪两者都匹配:
[00:29.02]Line 6 lyrics
[00:29]Line 6 lyrics
并为您提供第二个匹配组,以防您想要抓住歌词。
为了匹配标签,你可能需要一个正则表达式:
\[([a-z]+)\:(.+)\]
哪个匹配:
[au:Written by Kal Mann / Dave Appell, 1961]
[length: 2:23]
虽然这假设标签名称中没有数字。它为标记名称和值提供了两个捕获组。
为了做你想做的事情,我创建了一个jsFiddle,我认为它可以演示你想要的功能。它假定LRC数据由\n
个字符分隔。示例方法如下:
function test_LRC(str) {
var lyric_regex = /\[[0-9]{2}\:[0-9]{2}(\.[0-9]{2})?\](.+)/i;
var tag_regex = /\[([a-z]+)\:(.+)\]/i;
var LRC = str.split('\n');
var len = LRC.length;
var tags = [];
var valid = true;
for (var i = 0; i < len; i++) {
var line = LRC[i].trim();
if (line !== '') {
if (tag_regex.test(line)) {
var groups = tag_regex.exec(line);
tags.push({'tag': groups[1], 'value': groups[2].trim()});
} else if (!lyric_regex.test(line)) {
valid = false;
break;
}
}
}
return { 'valid': valid, 'tags': tags };
}