import requests
import re
#获取hush值和AlbumID
def gethush():
global musicname
musicname = input('请输入您要下载的歌曲名字:')
url = 'http://songsearch.kugou.com/song_search_v2?callback=jQuery1910026785707623246724_1490845878865&keyword={}&page=1&pagesize=30&userid=-1&%20%20clientver=&platform=WebFilter&tag=em&filter=2&iscorrection=1&privilege_filter=0&_=1490845878887'.format(musicname)
response = requests.get(url)
html = response.text
pattern = '"FileHash":"(.*?)","SQPayType".*?"AlbumID":"(.*?)"'
hush = re.search(pattern,html).group(1)
album = re.search(pattern,html).group(2)
return hush
#获取音乐下载链接
def getmusicurl(hush):
url = 'http://www.kugou.com/yy/index.php?r=play/getdata&hash={}'.format(hush)
response = requests.get(url)
html = response.text
pattern = '"play_url":"(.*?)","authors"'
music_url = re.search(pattern,html).group(1)
return music_url
#下载音乐
def downloadmusic(url):
session = requests.Session()
url = url.replace('\\','')
r = requests.get(url)
with open(r'd:\mp3\%s.mp3' % musicname, "wb") as f:
for chunk in r.iter_content(chunk_size=512):
if chunk:
print('正在下载:%s'% musicname)
f.write(chunk)
def main():
downloadmusic(getmusicurl(gethush()))
if __name__ == '__main__':
main()