基本信息
源码名称:python 爬取QQ音乐并下载至本地 示例源码
源码大小:2.13KB
文件格式:.py
开发语言:Python
更新时间:2018-04-23
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 2 元×
微信扫码支付:2 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
#爬取QQ音乐,3.21调试成功 import requests import urllib import json word = '雨蝶' res1 = requests.get('https://c.y.qq.com/soso/fcgi-bin/client_search_cp?&t=0&aggr=1&cr=1&catZhida=1&lossless=0&flag_qc=0&p=1&n=20&w=' word) jm1 = json.loads(res1.text.strip('callback()[]')) jm1 = jm1['data']['song']['list'] mids = [] songmids = [] srcs = [] songnames = [] singers = [] for j in jm1: try: mids.append(j['media_mid']) songmids.append(j['songmid']) songnames.append(j['songname']) singers.append(j['singer'][0]['name']) except: print('wrong') for n in range(0,len(mids)): res2 = requests.get('https://c.y.qq.com/base/fcgi-bin/fcg_music_express_mobile3.fcg?&jsonpCallback=MusicJsonCallback&cid=205361747&songmid=' songmids[n] '&filename=C400' mids[n] '.m4a&guid=6612300644') jm2 = json.loads(res2.text) vkey = jm2['data']['items'][0]['vkey'] srcs.append('http://dl.stream.qqmusic.qq.com/C400' mids[n] '.m4a?vkey=' vkey '&guid=6612300644&uin=0&fromtag=66') print('For ' word ' Start download...') x = len(srcs) for m in range(0,x): print(str(m) '***** ' songnames[m] ' - ' singers[m] '.m4a *****' ' Downloading...') try: #直接将远程数据下载到本地。 urllib.urlretrieve(url[, filename[, reporthook[, data]]]) #参数说明: #url:外部或者本地url #filename:指定了保存到本地的路径(如果未指定该参数,urllib会生成一个临时文件来保存数据); #reporthook:是一个回调函数,当连接上服务器、以及相应的数据块传输完毕的时候会触发该回调。我们可以利用这个回调函数来显示当前的下载进度。 #data:指post到服务器的数据。该方法返回一个包含两个元素的元组(filename, headers),filename表示保存到本地的路径,header表示服务器的响应头。 urllib.request.urlretrieve(srcs[m],'d:/music/' songnames[m] ' - ' singers[m] '.m4a') except: x = x - 1 print('Download wrong~') print('For [' word '] Download complete ' str(x) 'files !')