如何不用音乐播放器批量下载音乐?只需几分钟,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'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文件了不,想要页面好看,还得另外做个界面出来,下次整一个~

在这里插入图片描述

posted @ 2021-09-04 15:39  轻松学Python  阅读(1061)  评论(0编辑  收藏  举报