musicLrc = '''[00:03.50]传奇
[00:19.10]作词:刘兵 作曲:李健
[00:20.60]演唱:王菲
[00:26.60]
[04:40.75][02:39.90][00:36.25]只是因为在人群中多看了你一眼
[04:49.00]
[02:47.44][00:43.69]再也没能忘掉你容颜
[02:54.83][00:51.24]梦想着偶然能有一天再相见
[03:02.32][00:58.75]从此我开始孤单思念
[03:08.15][01:04.30]
[03:09.35][01:05.50]想你时你在天边
[03:16.90][01:13.13]想你时你在眼前
[03:24.42][01:20.92]想你时你在脑海
[03:31.85][01:28.44]想你时你在心田
[03:38.67][01:35.05]
[04:09.96][03:39.87][01:36.25]宁愿相信我们前世有约
[04:16.37][03:46.38][01:42.47]今生的爱情故事 不会再改变
[04:24.82][03:54.83][01:51.18]宁愿用这一生等你发现
[04:31.38][04:01.40][01:57.43]我一直在你身旁 从未走远
[04:39.55][04:09.00][02:07.85]'''
import time
# 创建字典,方便后续放时间:歌词
musicdict = {}
# 以换行切割musicLrc
list1 = musicLrc.splitlines()
# 循环遍历切割出来的列表
for each in list1:
# 将列表中的数据再次以"]"切割,列表的右边是歌词直接保存到word
word = each.split("]")[-1]
# 切割后的列表左边是时间列表,存入time1中
time1 = each.split("]")[:-1]
for t in time1:
# 遍历左边时间表【'[03:38.67''[01:35.05'】,消除"[",并且以:切割时间
time2 = t[1:].split(":")
# 将时间数字化,方便后面以key排序
timesum = float(time2[0])*60 + float(time2[1])
# 将歌词对应的时间,存入字典
musicdict[timesum] = word
# print(musicdict)
# 将字典中的key,转化为列表,方便用列表的sort()排序
list2 = list(musicdict.keys())
# 用sort()将时间按照从小到大顺序排列
list2.sort()
# 将歌曲按照时间的顺序依次打印出来
for i in range(len(list2)):
if i == 0:
# 歌词显示太慢,这里以十倍的速度打印
# 第一次休眠就是对应的key
time.sleep(list2[0]/10)
else:
# 第二次开始休眠就是对应的key减去上次的时间
time.sleep((list2[i]-list2[i-1])/10)
# 打印歌词
print(musicdict[list2[i]])
总结:python中很多语句可以叠加,很多单个会用,但是综合起来用,可能有点懵逼,所以需要多加练习。