headers = {
‘User-Agent’: ‘Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.90 Safari/537.36’
}
然后我们既然是要搜索下载的话,那不得先把搜索功能做出来。
def get_music_info():
“”“搜索功能”“”
music_info_list = []
name = input(‘请输入歌手或歌曲:’) #
page = input(‘请输入页码:’)
num = input(‘请输入当前页码需要返回的数据条数:’)
url = f’https://c.y.qq.com/soso/fcgi-bin/client_search_cp?p={page}&n={num}&w={name}’
response = requests.get(url, headers=headers).text # 获取到的是字符串
将response切分成json格式 类似字典 但是现在还是字符串
music_json = response[9:-1]
json转字典
music_data = json.loads(music_json) # 转换成 字典
print(music_data)
music_list = music_data[‘data’][‘song’][‘list’]
for music in music_list:
music_name = music[‘songname’] # 歌曲的名字
singer_name = music[‘singer’][0][‘name’] # 歌手的名字
songmid = music[‘songmid’]
music_info_list.append((music_name, singer_name, songmid))
return music_info_list
看看效果
获取加密的vkey
def get_purl(music_info_list):
“”“单首歌曲地址拼接”“”
music_data = []
for music in music_info_list:
music_name = music[0]
singer_name = music[1]
songmid = music[2]
url = ‘https://u.y.qq.com/cgi-bin/musicu.fcg?data={“req”:{“module”:“CDN.SrfCdnDispatchServer”,“method”:“GetCdnDispatch”,“param”:{“guid”:“8846039534”,“calltype”:0,“userip”:“”}},“req_0”:{“module”:“vkey.GetVkeyServer”,“method”:“CgiGetVkey”,“param”:{“guid”:“8846039534”,“songmid”:[“%s”],“songtype”:[0],“uin”:“1152921504784213523”,“loginflag”:1,“platform”:“20”}},“comm”:{“uin”:“1152921504784213523”,“format”:“json”,“ct”:24,“cv”:0}}’ % songmid
response = requests.get(url, headers=headers).json()
purl = response[‘req_0’][‘data’][‘midurlinfo’][0][‘purl’]
full_media_url = ‘http://dl.stream.qqmusic.qq.com/’ + purl
music_data.append(
{
‘music_name’: music_name,
‘singer_name’: singer_name,
‘full_media_url’: full_media_url
})
return music_data
如果你获取的数据 是 {} .json() 他会直接帮我们转换成字典。
然后实现下载
if 判断是否有歌曲下载文件夹,如果没有创建,就会自动创建一个歌曲下载文件夹。当然这个名字都可以自己改。
def save_music_mp3(music_data):
“”“下载歌曲”“”
if not os.path.exists(‘歌曲下载’):
os.mkdir(‘歌曲下载’)
for music in music_data:
music_name = music[‘music_name’]
singer_name = music[‘singer_name’]
full_url = music[‘full_media_url’]
music_response = requests.get(full_url, headers=headers).content
with open(‘歌曲下载/%s-%s.mp3’ % (music_name, singer_name), ‘wb’)as fp:
fp.write(music_response)
print(‘[%s]保存成功!’ % music_name)
if name == ‘main’:
现在能在网上找到很多很多的学习资源,有免费的也有收费的,当我拿到1套比较全的学习资源之前,我并没着急去看第1节,我而是去审视这套资源是否值得学习,有时候也会去问一些学长的意见,如果可以之后,我会对这套学习资源做1个学习计划,我的学习计划主要包括规划图和学习进度表。
分享给大家这份我薅到的免费视频资料,质量还不错,大家可以跟着学习
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!