zoukankan      html  css  js  c++  java
  • 以字典方式提取歌词

    s = '''[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]'''
    
    # 定义一个字典,保存歌曲信息
    song_dict = {}
    
    # 定义一个字典,保存歌词信息
    lrc_dict = {}
    
    # 按照换行进行切割
    str_list = s.splitlines()
    
    for string in str_list:
        # 判断是否是歌词信息
        if string[1].isdecimal():
            # [02:11.55][01:50.60][00:22.63]穿过幽暗的岁月
            # 按照']'进行切割
            lrc_list = string.split(']')
            # 提取歌词信息
            lrc_info = lrc_list[-1]
            # 提取时间信息
            time_info = lrc_list[:-1]
            # 遍历处理每个时间戳
            for time_str in time_info:
                # [02:11.55,去掉'['
                time_str = time_str[1:]
                # 02:01.09,按照':'进行切割
                time_info_list = time_str.split(':')
                # 提取分钟
                time_min = float(time_info_list[0])
                # 提取秒数
                time_sec = float(time_info_list[1])
                # 合并时间
                time = time_min * 60 + time_sec
                # 保存歌词及对应的时间戳
                lrc_dict[time] = lrc_info
        else:
            # [ti:蓝莲花]
            # 去掉两边的[]
            string = string[1:-1]
            # 按照':'进行切割
            song_list = string.split(':')
            # 保存到字典中
            if song_list[0] == 'ti':
                song_dict['标题'] = song_list[1]
            elif song_list[0] == 'ar':
                song_dict['艺术家'] = song_list[1]
            elif song_list[0] == 'al':
                song_dict['专辑'] = song_list[1]
    
    
    # 提取所有的时间戳
    time_list = list(lrc_dict)
    # 对时间戳进行降序排序
    time_list.sort(reverse=True)
    
    
    # 根据时间戳返回对应歌词
    def get_lrc_by_time(t):
        for i in time_list:
            if i <= t:
                return lrc_dict[i]
        return lrc_dict[time_list[-1]]
    
    
    # 下面的代码都是测试代码
    import time
    import os
    t = 0
    last_lrc = None
    while True:
        lrc = get_lrc_by_time(t)
        if last_lrc != lrc:
            # 清屏
            os.system('cls')
            for s in song_dict:
                print(s, song_dict[s])
            print()
            last_lrc = lrc
            print(lrc)
        time.sleep(0.5)
        t += 0.5
  • 相关阅读:
    warning: LF will be replaced by CRLF in ***. The file will have its original line endings in your working directory.
    GitHub出现Permissiondenied (publickey).
    浏览器编辑web页面的方法
    用scikit-learn进行LDA降维
    支持向量机原理(二) 线性支持向量机的软间隔最大化模型
    奇异值分解(SVD)原理与在降维中的应用
    scikit-learn K近邻法类库使用小结
    矩阵分解在协同过滤推荐算法中的应用
    精确率与召回率,RoC曲线与PR曲线
    异常点检测算法小结
  • 原文地址:https://www.cnblogs.com/liangliangzz/p/10222862.html
Copyright © 2011-2022 走看看