使用Python下载酷狗音乐

本文介绍了如何结合Python的Selenium和Urllib库,来自动化下载酷狗音乐平台上的歌曲,以野狼Disco为例,详细阐述了获取音频URL和使用Urllib进行下载的过程。
摘要由CSDN通过智能技术生成

使用Python+Selenium+Urllib下载酷狗歌曲

最近想下载一首歌,找了各大音乐平台,觉得在酷狗上下载更容易。

首先是获取原音频地址(本文以野狼disco为例),存储在<audio>标签里的src属性中。

from selenium import webdriver as wd
kugo_url="https://www.kugou.com/song/#hash=B6880A36D02561912C53831ACF305D0D&album_id=30181741"
dr = wd.Chrome()
dr.get(c)

ele = dr.find_
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值