解析‘蓝莲花’歌词
import os
歌词类
class Lrc:
def init(self, sec, lrc):
self.sec = sec
self.lrc = lrc
def __str__(self):
return '{} {}'.format(self.sec, self.lrc)
歌词管理类
class LrcManager:
def init(self, lrc_file):
self.lrc_file = lrc_file
self.lrc_list = []
self.song_dict = {}
self.jiexi()
def jiexi(self):
if not os.path.isfile(self.lrc_file):
print(self.lrc_file, '文件不存在')
return
# 打开文件
fp = open(self.lrc_file, encoding='utf-8')
# 读取文件,读取所有的行
lrc_list = fp.readlines()
# 去掉每个元素最后的\n
m = map(lambda s: s.strip(), lrc_list)
# 遍历处理每一条信息
for lrc_str in m:
# 判断是否是歌词信息
if lrc_str[1].isdecimal(): # 是歌词信息
# [02:11.55][01:50.60][00:22.63]穿过幽暗的岁月
# 按照']'进行切割
lrc_strs = lrc_str.split(']')
# 提取歌词信息
lrc_info = lrc_strs[-1]
# 提取时间信息
time_info = lrc_strs[:-1]
for t in time_info:
# [02:11.55
# 提取分钟数
min = float(t[1:3])
# 提取秒数
sec = float(t[4:])
# 合并时间
time = min * 60 + sec
# 创建歌词对象
lrc = Lrc(time, lrc_info)
# 保存歌词对象
self.lrc_list.append(lrc)
else: # 是歌曲信息
# [ti:蓝莲花]
# 提取选项
item = lrc_str[1:3]
# 提取内容
content = lrc_str[4:-1]
if item == 'ti':
self.song_dict['标题'] = content
elif item == 'ar':
self.song_dict['艺术家'] = content
elif item == 'al':
self.song_dict['专辑'] = content
# 对歌词列表按照时间戳进行降序排序
self.lrc_list.sort(key=lambda obj: obj.sec, reverse=True)
# 根据时间戳返回歌词
def get_lrc(self, sec):
for lrc in self.lrc_list:
if lrc.sec < sec:
return lrc.lrc
# 若没找到合适的歌词,则返回第一句
return self.lrc_list[-1]
lm = LrcManager(‘蓝莲花.txt’)
print(lm.get_lrc(10))
print(lm.get_lrc(20))
print(lm.get_lrc(30))
[ti:蓝莲花]
[ar:许巍]
[al:留声十年绝版青春北京演唱会]
[00:-01.70]蓝莲花
[00:-00.70]演唱:许巍
[00:00.00]
[00:00.70]没有什么能够阻挡
[00:06.01]你对*的向往
[00:11.43]天马行空的生涯
[00:16.99]你的心了无牵挂
[00:21.20]
[02:11.55][01:50.60][00:22.63]穿过幽暗的岁月
[02:16.93][01:55.60][00:27.81]也曾感到彷徨
[02:22.21][02:01.09][00:33.13]当你低头的瞬间
[02:27.62][02:06.33][00:38.32]才发觉脚下的路
[02:31.64][02:10.23][00:42.37]
[02:32.97][00:43.79]心中那*的世界
[02:38.23][00:49.50]如此的清澈高远
[02:43.30][00:54.31]盛开着永不凋零
[02:47.70][00:58.50]蓝莲花
[02:53.95][03:00.06][01:05.41]
总结:考察类和对象的全套知识,难点加重点,做这种题如果能轻而易举,那做做项目就可以开始了。
没别的办法,基础知识打牢,多敲多练。就像写文章,接下来就像每天写一篇日记一样,练一练,巩固巩固。