python爬取酷狗音乐json数据为空_【Python3爬虫】下载酷狗音乐上的歌曲

经过测试,可以下载要付费下载的歌曲(n_n)

准备工作:python3.5+pycharm

使用到的库:requests,re,json

步骤:

打开酷狗音乐的官网,输入想要搜索的歌曲(例如《天后》),然后回车搜索,得到如下页面:

右键检查或者按f12打开开发者工具,点击js选项,查找到如下信息,filename就是返回的歌手名和歌曲名信息,我们要将其提取出来:

由于这个网址返回的不是标准的json格式,所以要先进行如下处理,然后再转换成json格式:

res = requests.get(url).text

js = json.loads(res[res.index('(') + 1:-2])

提取到歌曲信息之后,我们输入一个序号代表要下载的歌曲序号,然后把歌曲下载下来就好了。

运行截图:

附上源码:

1 import requests

2 import json

3 import re

4

5

6 def get_song(x):

7 url = "http://songsearch.kugou.com/song_search_v2?cal

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是一个简单的 Python 爬虫实现,可以酷狗音乐下载到本地。 ```python import requests import os # 搜索歌曲的 API search_url = 'http://songsearch.kugou.com/song_search_v2' # 获歌曲的播放地址和信息的 API play_url = 'http://www.kugou.com/yy/index.php' # 下载歌曲的 API download_url = 'http://www.kugou.com/yy/index.php?r=play/getdata' # 定义请求头 headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/89.0.4389.82 Safari/537.36' } # 定义搜索歌曲的函数 def search_song(keyword): # 构造请求参数 params = { 'keyword': keyword, 'page': 1, 'pagesize': 30, } # 发送请求 response = requests.get(search_url, params=params, headers=headers) # 获搜索结果 result = response.json() # 解析搜索结果,获歌曲ID和Hash值 song_id = result['data']['lists'][0]['SongID'] hash_value = result['data']['lists'][0]['FileHash'] # 返回歌曲ID和Hash值 return song_id, hash_value # 定义获歌曲播放地址和信息的函数 def get_song_info(song_id, hash_value): # 构造请求参数 params = { 'r': 'play/getdata', 'hash': hash_value, 'mid': '42c9c3f9f0e8e8d8a1e6f2cceddbf5b6', 'platid': 4, } # 发送请求 response = requests.get(play_url, params=params, headers=headers) # 获响应结果 result = response.json() # 解析响应结果,获歌曲的播放地址和信息 play_url = result['data']['play_url'] song_name = result['data']['audio_name'] singer_name = result['data']['author_name'] # 返回歌曲的播放地址和信息 return play_url, song_name, singer_name # 定义下载歌曲的函数 def download_song(play_url, song_name): # 发送请求,获文件流 response = requests.get(play_url, headers=headers, stream=True) # 获文件大小 file_size = int(response.headers['Content-Length']) # 打印提示信息 print('正在下载:{},文件大小:{:.2f} MB'.format(song_name, file_size / 1024 / 1024)) # 创建文件夹 if not os.path.exists('songs'): os.mkdir('songs') # 拼接文件路径 file_path = os.path.join('songs', song_name + '.mp3') # 写入文件 with open(file_path, 'wb') as f: for chunk in response.iter_content(chunk_size=1024): f.write(chunk) # 打印提示信息 print('下载完成!') # 主函数 if __name__ == '__main__': # 输入歌曲名 keyword = input('请输入歌曲名称:') # 搜索歌曲 song_id, hash_value = search_song(keyword) # 获歌曲的播放地址和信息 play_url, song_name, singer_name = get_song_info(song_id, hash_value) # 下载歌曲 download_song(play_url, song_name + '-' + singer_name) ``` 这个爬虫程序需要使用到 requests 库,如果没有安装的话,可以通过 pip 安装: ```python pip install requests ``` 运行程序后,输入歌曲名称,程序会自动搜索歌曲下载到本地。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值