我们想听的歌,在特定音乐软件才有,但是又嫌弃太麻烦,不想下载软件,这个好说,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'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__': music_info_list = get_music_info() music_data = get_purl(music_info_list) save_music_mp3(music_data)
现在我们看看效果
页码和数据条数可以不输入,他会默认下载第一页,一页是十首歌。
你也可以你下载其他页
然后我只想要一首
这是刚刚自动获取到的歌曲
当然,只用代码多无趣,我们还可以实现把代码打包,做成exe 程序,直接运行~
具体怎么做我就不一 一赘述了,方法简单,百度一下分分钟就做的出来。我给大家看下效果。
虽然只有一个命令框页面,单好歹也是个不用安装Python也能运行的exe文件了不,想要页面好看,还得另外做个界面出来,下次整一个~