教你⽤Python批量下载⾳乐功能,⽆需安装播放器,直接下载!
齐豫 齐秦我们想听的歌,在特定⾳乐软件才有,但是⼜嫌弃太⿇烦,不想下载软件,这个好说,Python随随便便就实现了!
我们以湫湫⾳乐为例,做⼀个搜索下载⾳乐的功能。
在开始之前,给⼤家推荐⼀个交流的地⽅,有啥问题都可以在这交流~
很多⼩伙伴因为没有好的学习资料或者遇到问题得不到⾼效解决,导致⾃⼰学习坚持不下去,所以我也在这准备了很多学习资料,⼤家都可以 包括今天的代码和视频教程,对⽂章看不懂的话也可以看视频。
亲情式的爱情歌词⽤到的软件是anaconda5.2.0(python3.6.5)和pycharm,anaconda是⾃带Python的,安装了anaconda就不⽤安装Python了。
然后需要安装⼀个requests库,键盘按住win+r,在弹出的搜索框输⼊cmd ,按回车 ,在新弹出的命令提⽰符窗⼝输⼊ pip install requests 即可完成安装。
啰嗦了点,但是对零基础友好⼀点。
知识点:
requests
json
pprint
OK,开始尝试吧
先安排⼀下要⽤的模块,导⼊进来。
import requests
import json
import os
我们既然要爬⼀个⽹站,那么如果有反扒的话,肯定要解决这个问题,像今天可以⽤ headers 模块来模拟成浏览器访问⽹站。
那么 headers 在哪⾥呢?
在浏览器页⾯上点击:右键–>检查–>(或者直接按F12),剩余按照图中显⽰操作,需要按Fn+F5刷新出⽹页来
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'c.y.qq/soso/fcgi-bin/client_search_cp?p={page}&n={num}&w={name}'
response = (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 ='u.y.qq/cgi-bin/musicu.fcg?data={"req":{"module":"CDN.SrfCdnDispatchServer","method":"GetCdnDispatch","param":{"guid":"8846039 534","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 = (url, headers=headers).json()
purl = response['req_0']['data']['midurlinfo'][0]['purl']
full_media_url ='dl.stream.qqmusic.qq/'+ 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 ists('歌曲下载'):
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 = (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__':
music_info_list = get_music_info()
music_data = get_purl(music_info_list)
save_music_mp3(music_data)
现在我们看看效果
页码和数据条数可以不输⼊,他会默认下载第⼀页,⼀页是⼗⾸歌。
你也可以你下载其他页
然后我只想要⼀⾸
这是刚刚⾃动获取到的歌曲