网易云歌词获取

前言

在写博客的时候,想往文章里面插入音乐。虽然网易云有外链的功能提供,但是有一些网易云没有版权的音乐就不支持外链,所以想要得到这些没有版权的音乐,就需要另想办法了。

刚好看到有一款插件可以得到这些歌曲,但是歌词的请求链接却一直都抓不到。无奈之下,只好向度娘求助了。

搜索一番后,发现可以根据网易云歌曲的id,拼接请求歌词的链接,但是请求网页版返回的是json字符串类型的数据,有干扰信息。所以就想着能不能利用Python来处理一下,减少一点步骤,搞个“一键获取”之类的功能。

例如:

歌曲:Way Back Home
链接:https://music.163.com/#/song?id=863046037
歌词链接:http://music.163.com/api/song/media?id=863046037

需要的只是lyric字段的内容.

歌词.png

步骤:

  1. 截取歌曲链接的id
  2. 将id拼接进去歌词链接中
  3. 请求歌词后,获取lyric字段的内容

实现

代码:

import re
import requests
import json

class neteasse:
    def __init__(self, url):
        self.url = url
        self.link = 'http://music.163.com/api/song/media?id='
        self.headers = {
            'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:58.0) Gecko/20100101 Firefox/58.0'}

    def get_song_id(self):
        '''
        根据传入的链接,截取出歌曲的id
        :param url: str
        :return: str
        '''
        # 'https://music.163.com/#/song?id=863046037'
        if self.url != "":
            id = re.split('id=', self.url)[1]
            return id
        else:
            return ""

    def get_lyrics(self):
        '''
        根据歌曲id,请求获取歌词
        :param id: str
        :return: str
        '''
        id = self.get_song_id()
        if id != "":
            self.link += id
            web_data = requests.get(url=self.link, headers=self.headers).text
            json_data = json.loads(web_data)
            try:
                return json_data['lyric']
            except BaseException:
                return "歌曲id错误,请检查后重试!!!"

        else:
            return "链接错误,请检查后重试!!!"


if __name__ == '__main__':
    url = 'https://music.163.com/#/song?id=863046037'
    net = neteasse(url)
    lyric = net.get_lyrics()
    print(lyric)

输出的内容就是这首歌的歌词了。

歌词.png

之后只需要复制到插件中,就可以在博客中播放没有办法使用外链的音乐了。效果可以访问我的博客站点:https://donlex.cn

最后

Python的小脚本真的很有趣,而且写起来并不难,却能够极大的给我们方便。
如果你有什么有趣的小脚本,可以留言告诉我哦!
更多内容,请关注公众号:“Python绿洲
好多小脚本在这里:https://github.com/stormdony/python_demo

推荐阅读更多精彩内容