重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章主要介绍“Python怎么制作各大音乐平台的聚合的音乐下载器”,在日常操作中,相信很多人在Python怎么制作各大音乐平台的聚合的音乐下载器问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python怎么制作各大音乐平台的聚合的音乐下载器”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
成都创新互联公司网站建设公司,提供成都网站建设、成都网站设计,网页设计,建网站,PHP网站建设等专业做网站服务;可快速的进行网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,是专业的做网站团队,希望更多企业前来合作!
转载地址
https://blog.csdn.net/fei347795790?t=1
需要安装一个辅助模块 prettytable,用于美化控制台的表格输出
pip install prettytable
搜索音乐
以下载 QQ 音乐为例,在首页(https://y.qq.com/) 上的搜索框中搜索 <<厚颜无耻>>, 打开 F12 的控制台面板,可以找到如下图的搜索链接,这个链接返回的是一个音乐列表的 json 串
def get_request(self, url): try: headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/85.0.4183.102 Safari/537.36' } response = requests.get(url, headers = headers) if response.status_code == 200: return response except Exception as e: print("请求出错:", e) return None def search_music(self, key): # 20: 查询 20 条数据,key:关键字 url = 'https://c.y.qq.com/soso/fcgi-bin/client_search_cp?p=1&n=%d&w=%s' % (20, key) resp = self.get_request(url) resp_json = json.loads(resp.text[9:][:-1]) data_song_list = resp_json['data']['song']['list'] song_list = [] for song in data_song_list: singers = [s.get("name", "") for s in song.get("singer", "")] song_list.append({'name': song['songname'], 'songmid': song['songmid'], 'singer': '|'.join(singers)}) return song_list
示例结果:
[{'name': '富士山下', 'songmid': '003dtkNk26WhJD', 'singer': '陈奕迅'}, {'name': '不要说话', 'songmid': '002B2EAA3brD5b', 'singer': '陈奕迅'}, ...., {'name': '最佳损友', 'songmid': '003hFxQh376Cv5', 'singer': '陈奕迅'}]
把音乐列表页中的歌曲点击到播放音乐的页面,在控制面板找到多个以 m4a 结尾的音乐实际链接
def download_url(self, song): guid = str(random.randrange(1000000000, 10000000000)) purl_url = 'https://u.y.qq.com/cgi-bin/musicu.fcg?' \ '&data={"req":{"param":{"guid":" %s"}},' \ '"req_0":{"module":"vkey.GetVkeyServer","method":"CgiGetVkey","param":{"guid":"%s","songmid":["%s"],"uin":"%s"}},"comm":{"uin":%s}}' \ % (guid, guid, song['songmid'], 0, 0) resp = self.get_request(purl_url) if resp is None: return 'N', 'None', '.m4a' resp_json = json.loads(resp.text) purl = resp_json['req_0']['data']['midurlinfo'][0]['purl'] # 有些音乐在网站上不能听 if len(purl) < 1: msg = 'N' download_url = 'http://ws.stream.qqmusic.qq.com/' + purl song_data = self.get_request(download_url) if song_data: msg = 'Y' return msg, download_url, '.m4a'
示例结果:
只有一个域名的地址的下载链接表示这个音乐只能在客户端听,网页版听不了
到这里已经完了 QQ 音乐的搜索、抓取脚本,用同样的方式抓取咪咕音乐(http://m.music.migu.cn)做成咪咕音乐脚本,咪咕音乐更容易爬取
主界面的主要功能就是以表格的方式显示搜索到的音乐和以序号的方式下载音乐
import os from qqMusic import QQMusic from miguMusic import MiGuMusic from prettytable import PrettyTable class MusicBox(object): def __init__(self): pass def download(self, data, songName, type): save_path = 'music/' + songName + '.' + type file = 'music' if os.path.exists(file): pass else: os.mkdir('music') try: print("{}下载中.....".format(songName), end='') with open(save_path, 'wb') as f: f.write(data) print("已下载完成") except Exception as err: print("文件写入出错:", err) return None def main(self): print('请输入需要下载的歌曲或者歌手:') key = input() print('正在查询..\033[32mQQ音乐\033[0m', end='') qqMusic = QQMusic() qq_song_list = qqMusic.main(key) print('...\033[31m咪咕音乐\033[0m') miguMusic = MiGuMusic() migu_song_list = miguMusic.main(key) qq_song_list.extend(migu_song_list) song_dict = {} for song in qq_song_list: key = song['name'] + '\\' + song['singer'] s = song_dict.get(key) if s: if s['msg'] != 'Y': song_dict[key] = song else: song_dict[key] = song i = 0 table = PrettyTable(['序号', '歌手', '下载', '歌名']) table.border = 0 table.align = 'l' for song in list(song_dict.values()): i = i + 1 table.add_row([str(i), song['singer'], song['msg'], song['name']]) print(table) while 1: print('\n请输入需要下载,按 q 退出:') index = input() if index == 'q': return song = list(song_dict.values())[int(index) - 1] data = qqMusic.get_request(song['downloadUrl']) if song['msg'] == 'Y': self.download(data.content, song['name'], song['type']) else: print('该歌曲不允许下载') if __name__ == '__main__': musicBox = MusicBox() musicBox.main()
到此,关于“Python怎么制作各大音乐平台的聚合的音乐下载器”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!