虾米音乐flac高品质下载
import requests
import re
import time
headers={
'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/74.0.3729.169 Safari/537.36',
}
通过抓取该url的信息进行音乐文件解析,访问过多可能会返回403,建议在浏览器打开后复制保存至txt文件中,作者保存在resource.txt文件,结果是一个json格式字符串,但尝试多次解析仍有遗漏,本文用正则获取音乐id,名字,以及下载链接
# url = 'https://music.xiami.com/resource/collect/v2/detail/304875130/282193940/1527860959?auth_key=1612323469-0-0-5658d0741a819ff4414a081ac14563b1'
with open("./resource.txt","r",encoding='utf-8') as fp:
content = fp.readline()
songInfo = {}
songInfo['musicName'] =re.findall('"songName":"(.*?)",',content),
songInfo['musicId']=re.findall('{"songId":(.*?),',content),
songInfo['musicFiles']=re.findall('"listenFiles":\[{"listenFile":"(.*?)",',content)
for i in range(len(songInfo['musicFiles'])):
targetUrl = songInfo['musicFiles'][i] #+ songInfo['musicName'][0][i] + songInfo['musicId'][0][i]
print(str(i)+" : ",targetUrl)
time.sleep(0.5)
res = requests.get(url=targetUrl,headers=headers)
with open("./music/"+songInfo['musicName'][0][i]+".mp3","wb") as fp:
fp.write(res.content)