- 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& clientver=&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()
来源: http://www.bubuko.com/infodetail-2662135.html