基本信息
源码名称:python 爬取QQ音乐并下载至本地 示例源码
源码大小:2.13KB
文件格式:.py
开发语言:Python
更新时间:2018-04-23
   友情提示:(无需注册或充值,赞助后即可获取资源下载链接)

     嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300

本次赞助数额为: 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 !')