最新酷狗音乐反爬来袭,Python掌握酷狗排行榜加密规则(1)

爬取目标


网址:酷我音乐

在这里插入图片描述

工具使用


开发工具:pycharm

开发环境:python3.7, Windows10

使用工具包:requests,re

项目思路解析


找到需要解析的榜单数据

在这里插入图片描述

随意点击一个歌曲获取到音乐的详情数据 通过抓包的方式获取到音乐播放数据

在这里插入图片描述

找到MP3的数据提交地址 mp3数据来自于这个url地址

在这里插入图片描述在这里插入图片描述

提交数据的网址:

https://wwwapi.kugou.com/yy/index.php?r=play/getdata&callback=jQuery19102816534571347611_1626783818555&hash=A38449E76C74D45825F565C1FDB825C0&dfid=3dKstH1sJdRa44o6Vj0ZIryF&mid=4458f6d567640b39de367a394d69879e&platid=4&album_id=40437970&_=1626783818556

将多个网址数据进行对比看看哪些参数是需要自行修改的 在这里插入图片描述 变化的url数据有3个

  • hash

  • album_id

  • _

_ 可以明显看出来是时间戳 需要获取到对应的hash以及album_id的值 来到主页找寻对应的歌曲id数据 发现数据来自网页源代码 在这里插入图片描述

歌曲的数据都是来自网页源代码

在这里插入图片描述

梳理整体思路:

  • 从首页源码里提取出对应的hash、album_id值

  • 组合成新的url地址

  • 获取到json数据总的歌曲播放地址##

简易源码分析


本章内容只限学习,切勿用作其他用途!!!!!

import requests

import re

import time

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数Python工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Python开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注Python)

料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!**

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以扫码获取!!!(备注Python)

img
  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用 requests 和 BeautifulSoup 库来爬取酷狗音乐排行榜。 首先,需要先确定要爬取的排行榜地址,比如:http://www.kugou.com/yy/rank/home/1-8888.html?from=rank。然后用 requests 库发送 GET 请求获取页面内容。 ```python import requests url = 'http://www.kugou.com/yy/rank/home/1-8888.html?from=rank' headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.3'} response = requests.get(url, headers=headers) html = response.text ``` 接下来,用 BeautifulSoup 库解析 HTML 内容,并提取排行榜中歌曲的信息。 ```python from bs4 import BeautifulSoup soup = BeautifulSoup(html, 'lxml') rank_list = soup.find('ul', class_='rank-list') song_list = rank_list.find_all('li') for song in song_list: # 获取歌曲名 song_name = song.find('a', class_='pc_temp_songname').text.strip() # 获取歌手名 song_singer = song.find('a', class_='pc_temp_singername').text.strip() # 获取歌曲排名 song_rank = song.find('span', class_='pc_temp_num').text.strip() print('{}\t{}\t{}'.format(song_rank, song_name, song_singer)) ``` 完整代码如下: ```python import requests from bs4 import BeautifulSoup url = 'http://www.kugou.com/yy/rank/home/1-8888.html?from=rank' headers = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.3'} response = requests.get(url, headers=headers) html = response.text soup = BeautifulSoup(html, 'lxml') rank_list = soup.find('ul', class_='rank-list') song_list = rank_list.find_all('li') for song in song_list: # 获取歌曲名 song_name = song.find('a', class_='pc_temp_songname').text.strip() # 获取歌手名 song_singer = song.find('a', class_='pc_temp_singername').text.strip() # 获取歌曲排名 song_rank = song.find('span', class_='pc_temp_num').text.strip() print('{}\t{}\t{}'.format(song_rank, song_name, song_singer)) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值