今天学到一个好玩的东西,就是用python把歌词分解,当你可以做到把这首歌和程序同时运行,那么就可以做到歌词与声音同步。
代码:
string = '''[ti:蓝莲花]
[ar:许巍]
[al:时光漫步]
[by:(5nd音乐网)www.5nd.com]
[offset:500]
[00:00.20]蓝莲花
[00:00.80]没有什么能够阻挡
[00:06.53]你对自由地向往
[00:11.59]天马行空的生涯
[00:16.53]你的心了无牵挂
[00:20.81]龙腾世纪
[02:11.27][01:50.22][00:21.95]穿过幽暗地岁月
[02:16.51][01:55.46][00:26.83]也曾感到彷徨
[02:21.81][02:00.60][00:32.30]当你低头地瞬间
[02:26.79][02:05.72][00:37.16]才发觉脚下的路
[02:29.72][02:09.22][00:42.03]龙腾世纪
[02:32.17][00:42.69]心中那自由地世界
[02:37.20][00:47.58]如此的清澈高远
[02:42.32][00:52.72]盛开着永不凋零
[02:47.83][00:57.47]蓝莲花'''
# 先将歌词按照换行符进行切割
lrc_list = string.splitlines()
# print(lrc_list)
# 定义一个空列表,用来保存所有的歌词
info = []
# 遍历这个列表,依次的解析每一句歌词
for lrc in lrc_list:
# 判断这个lrc是不是歌词,以 [0 开头的说明是歌词,否则不是歌词
if not lrc.startswith('[0'):
continue
# print(lrc)
# 解析歌词
'''
[00:00.20]蓝莲花
[02:11.27][01:50.22][00:21.95]穿过幽暗地岁月
解析的结果,键是浮点,值是歌词,放到字典里面,字典放到列表里面
'''
# 将歌词按照 ] 进行切割
info_list = lrc.split(']')
# print(info_list)
# 从列表里面得到歌词
geci = info_list[-1]
# 得到时间
# print(info_list[:-1])
for timeinfo in info_list[:-1]:
dic = {}
# '[02:11.27' 将这个字符解析为浮点的时间
# 干掉最前面 [
timeinfo = timeinfo[1:]
# 02:11.27
# 将其使用冒号进行切割
time_list = timeinfo.split(':')
# 得到分钟
minute = int(time_list[0])
# 得到秒数
second = float(time_list[1])
# 得到以秒为单位的时间
time_ = minute*60 + second
# print(time_, geci, sep='====>')
dic['time'] = time_
dic['lrc'] = geci
# print(dic)
# 将歌词保存到字典上
info.append(dic)
# print(info)
# 对列表里面的字典按照时间进行排序
info.sort(key=lambda x: x['time'],reverse = True)
# print(info)
def get_lrc(ftime):
for lrc_dic in info:
if ftime >= lrc_dic['time']:
return lrc_dic['lrc']
import os, time
i = 0
while 1:
# 给我一个时间,我返回你一句对应的歌词
lrc = get_lrc(i)
os.system('cls')
print(lrc)
i += 0.5
time.sleep(0.5)
可能有稍微的误差: