qq刷屏代码可复制_爬虫获取QQ音乐的歌手音乐信息

【一、项目目标】

获取 QQ 音乐指定歌手单曲排行指定页数的歌曲的歌名、专辑名、播放链接。

由浅入深,层层递进,非常适合刚入门的同学练手。

【二、需要的库】

主要涉及的库有:requests、json、openpyxl

【三、项目实现】

1.了解 QQ 音乐网站的 robots 协议

qq刷屏代码可复制_爬虫获取QQ音乐的歌手音乐信息_第1张图片

只禁止播放列表,可以操作。

2.进入 QQ 音乐主页 https://y.qq.com/

3.输入任意歌手,比如张杰

qq刷屏代码可复制_爬虫获取QQ音乐的歌手音乐信息_第2张图片

4.打开审查元素(快捷键 Ctrl+Shift+I)

qq刷屏代码可复制_爬虫获取QQ音乐的歌手音乐信息_第3张图片

5.分析网页源代码 Elements,发现无歌曲信息,无法使用 BeautifulSoup,如下图所示,结果为空。

qq刷屏代码可复制_爬虫获取QQ音乐的歌手音乐信息_第4张图片

qq刷屏代码可复制_爬虫获取QQ音乐的歌手音乐信息_第5张图片

6.点击 Network,看数据在不在 XHR(无刷新更新页面),我的经验是先看 Size 最大的,然后分析 Name,查看 Preview,果然在里面!

qq刷屏代码可复制_爬虫获取QQ音乐的歌手音乐信息_第6张图片

qq刷屏代码可复制_爬虫获取QQ音乐的歌手音乐信息_第7张图片

将response格式化后显示内容如上

7.点击 Headers,拿到相关参数。如下图,仔细观察url 与 Query String Parameters 参数的关系,发现url 中的 w 代表歌手名,p 代表页数

https:// c.y.qq.com/soso/fcgi-bi n/client_search_cp?ct=24&qqmusic_ver=1298&new_json=1&remoteplace=txt.yqq.song&searchid=63546055528113198&t=0&aggr=1&cr=1&catZhida=1&lossless=0&flag_qc=0&p=1&n=10&w=%E5%BC%A0%E6%9D%B0&g_tk_new_20200303=5381&g_tk=5381&loginUin=0&hostUin=0&format=json&inCharset=utf8&outCharset=utf-8¬ice=0&platform=yqq.json&needNewCode=0

其中:p=1&n=10&w=%E5%BC%A0%E6%9D%B0

qq刷屏代码可复制_爬虫获取QQ音乐的歌手音乐信息_第8张图片

8.通过 json 代码实现,首先小试牛刀,爬取第一页的数据,url 直接复制过来。成功!

qq刷屏代码可复制_爬虫获取QQ音乐的歌手音乐信息_第9张图片

其中:分析json获取歌曲列表,获取播放链接

qq刷屏代码可复制_爬虫获取QQ音乐的歌手音乐信息_第10张图片

qq刷屏代码可复制_爬虫获取QQ音乐的歌手音乐信息_第11张图片

9.引入 params 参数,实现指定歌手、指定页数的查询。
注意代码url为上一步url中“?”之前的部分, params两边的参数都需要加 ’’,requests.get 添加 params,参数(也可顺便添加 headers 参数)

qq刷屏代码可复制_爬虫获取QQ音乐的歌手音乐信息_第12张图片

10. 添加存储功能,保存到本地(Excel)。也可保存为 csv 格式或存入数据库,操作类似。

qq刷屏代码可复制_爬虫获取QQ音乐的歌手音乐信息_第13张图片

qq刷屏代码可复制_爬虫获取QQ音乐的歌手音乐信息_第14张图片

【四、总结】

1.爬取qq音乐比爬取豆瓣等网站稍难,所需信息不在源代码中,需查看xhr

2.通过xhr爬取数据一般要使用json,格式为:

res = requests.get(url)
json = res.json()
list = json['']['']

3.仅供练手参考,不建议爬取太多数据,给服务器增大负荷

4.Python爬取QQ音乐数据(二)将为大家带来如何爬取指定歌曲的歌词和评论使用selenium,并生成词云wordcloud

你可能感兴趣的:(qq刷屏代码可复制,爬虫xhr打开网页为空,获取上一步url)