【Python爬虫】用Python爬取网易云热歌榜等榜单的歌手歌词歌曲以及时长

前言

编码不易,请支持原创!

一、爬取目标

网易云热歌榜飙升榜原创榜新歌榜

飙升榜 - 排行榜 - 网易云音乐 (163.com)

新歌榜 - 排行榜 - 网易云音乐 (163.com)

原创榜 - 排行榜 - 网易云音乐 (163.com)

热歌榜 - 排行榜 - 网易云音乐 (163.com)

获取榜单里面所有歌曲的歌名、歌手名字、时长、歌词、音频文件

并形成csv、txt、mp3等结果输出

二、爬取结果展示

图片

图片

图片

图片

三、代码过程解析

1. 导入模块:

  • os:用于与操作系统交互,如创建文件夹。

  • time:用于时间相关的功能,但在这段代码中没有使用。

  • pandas:用于数据处理和CSV文件操作。

  • PyQuery:用于解析HTML文档。

  • requests:用于发送HTTP请求。

  • json:用于处理JSON数据。

  • csv:用于CSV文件的读写操作。

  • re:正则表达式模块,用于字符串匹配和替换。

图片

2. Wangyi_yun类:

  • 这个类用于处理网易云音乐的数据。

  • __init__方法初始化类的实例,设置请求头和URL。

  • get_page方法发送HTTP请求,获取网页源代码。

  • get_data方法使用PyQuery解析HTML,提取歌曲信息。

  • get_download方法下载歌曲并保存到本地。

  • write_csv方法将歌曲信息写入CSV文件。

  • main方法是生成器,用于迭代歌曲信息。

  • fetchData方法用于获取所有歌曲数据。

  • 图片

3. sanitize_filename函数:

  • 用于清理文件名,移除非法字符。

  • 图片

4. get_lyric函数:

  • 根据歌曲ID获取歌词。

  • 图片

5. 主程序:

  • 设置请求头。

  • 初始化Wangyi_yun对象,传入音乐榜单ID。

  • 使用main方法获取歌曲信息,并写入CSV文件。

  • 使用pandas读取CSV文件,添加序号列,然后保存回CSV文件。

  • 使用fetchData方法获取歌曲数据,然后尝试下载歌曲和歌词。

四、获取完整源码

编码不易,请支持原创!

本案例完整爬虫源码及csv、txt、mp3等结果文件,关注后回复网易云可获取↓

获取后,有任何代码问题请留言!

任何疑问可以直接后台留言,蛋蛋会及时回复

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值