找传奇、传世资源到传世资源站!

python 爬取QQ音乐并下载至本地 示例源码

8.5玩家评分(1人评分)
下载后可评
介绍 评论 失效链接反馈

from clipboard
#爬取QQ音乐,3.21调试成功import requestsimport urllibimport jsonword = '雨蝶'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 !')

评论

发表评论必须先登陆, 您可以 登陆 或者 注册新账号 !


在线咨询: 问题反馈
客服QQ:174666394

有问题请留言,看到后及时答复