前言
在写博客的时候,想往文章里面插入音乐。虽然网易云有外链的功能提供,但是有一些网易云没有版权的音乐就不支持外链,所以想要得到这些没有版权的音乐,就需要另想办法了。
刚好看到有一款插件可以得到这些歌曲,但是歌词的请求链接却一直都抓不到。无奈之下,只好向度娘求助了。
搜索一番后,发现可以根据网易云歌曲的id,拼接请求歌词的链接,但是请求网页版返回的是json字符串类型的数据,有干扰信息。所以就想着能不能利用Python来处理一下,减少一点步骤,搞个“一键获取”之类的功能。
例如:
需要的只是lyric字段的内容.
歌词.png
步骤:
截取歌曲链接的id
将id拼接进去歌词链接中
请求歌词后,获取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
之后只需要复制到插件中,就可以在博客中播放没有办法使用外链的音乐了。效果可以访问我的博客站点:
最后
Python的小脚本真的很有趣,而且写起来并不难,却能够极大的给我们方便。
如果你有什么有趣的小脚本,可以留言告诉我哦!
更多内容,请关注公众号:“Python绿洲”
好多小脚本在这里:https://github.com/stormdony/python_demo