使用js解析歌词文件(lrc格式歌词)

首发地址:https://www.hsmus.top/202101235.html

像音乐播放器一样,可以把歌词文件解析为方便使用的对象

效果如下:
解析效果

代码如下:
用法:

/***** 用法 ******/
const lrc = `
        [ti:沙漠骆驼]
[ar:展展与罗罗]
[al:]
[by:芥末]

[00:00.00]沙漠骆驼 - 展展与罗罗
[00:03.00]作词:展展与罗罗
[00:06.00]作曲:展展与罗罗
[00:09.00]歌词编辑:果果
[00:18.00]
[00:26.21]我要穿越这片沙漠
[00:28.24]找寻真的自我
[00:30.39]身边只有一匹骆驼陪我
[00:34.75]这片风儿吹过
[00:36.92]那片云儿飘过
[00:39.15]突然之间出现爱的小河
[00:43.60]我跨上沙漠之舟
[00:45.77]背上烟斗和沙漏
[00:47.88]手里还握着一壶烈酒
[05:24.97]END `;
const result = parseLyric(lrc)
console.log(result);
function parseLyric(lyric) {
            const lrcObj = {
                ti: '',
                ar: '',
                al: '',
                by: '',
                lrc: []
            };

        /*
            [ar:艺人名]
            [ti:曲名]
            [al:专辑名]
            [by:编者(指编辑LRC歌词的人)]
            [offset:时间补偿值] 其单位是毫秒,正值表示整体提前,负值相反。这是用于总体调整显示快慢的。
        */

            const lrcArr = lyric.split("\n").filter(function (value) {
                // 1.通过回车去分割歌词每一行,遍历数组,去除空行空格
                return value.trim() !== ''
            }).map(function (value) {
                // 2.解析歌词
                const line = parseLyricLine(value.trim())
                // console.log(line);
                if (line.type === 'lyric') {
                    lrcObj.lrc.push(line.data)
                } else {
                    lrcObj[line.type] = line.data
                }
                return value.trim();
            })

            function parseLyricLine(line) {
                const tiArAlByExp = /^\[(ti|ar|al|by):(.*)\]$/
                const lyricExp = /^\[(\d{2}):(\d{2}).(\d{2})\](.*)/
                let result
                if ((result = line.match(tiArAlByExp)) !== null) {
                    return {
                        type: result[1],
                        data: result[2]
                    }
                } else if ((result = line.match(lyricExp)) !== null) {
                    return {
                        type: 'lyric',
                        data: {
                            time: {
                                m: result[1],
                                s: result[2],
                                ms: result[3]
                            },
                            lyric: result[4].trim()
                        }
                    }
                }
            }

            return lrcObj;
        }

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值