今天學到一個好玩的東西,就是用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)
可能有稍微的誤差: