基本信息
源码名称: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 !')