Python爬取网易云音乐网易云音乐歌手歌曲和歌单,并下载到本地

仅供学习参考

很多人学习python,不知道从何学起。
很多人学习python,掌握了基本语法过后,不知道在哪里寻找案例上手。
很多已经做案例的人,却不知道如何去学习更加高深的知识。
那么针对这三类人,我给大家提供一个好的学习平台,免费领取视频教程,电子书籍,以及课程的源代码!
QQ群:101677771

Python爬取网易云音乐网易云音乐歌手歌曲和歌单,并下载到本地
①找到要下载歌手歌曲的链接,这里用的是:
https://music.163.com/#/artist?id=10559
要提前建好保存文件夹:path1 = "D:/360下载/网易云音乐/1/"
然后更改你要保存的目录,目录要先建立好文件夹,例如我的是保存在D盘-360下载-网易云音乐-1文件夹内,就可以完成下载。如果文件夹没有提前建好,会报错[Errno 2] No such file or directory。

②找到要下载歌单的链接,这里用的是:
https://music.163.com/#/playlist?id=5175828159
要提前建好保存文件夹:path2 = "D:/360下载/网易云音乐/2/"
只能下载前面10首。
之后的歌曲信息服务器不给数据,无法拿到

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是Python爬取网易云音乐数据的示例代码: ```python import requests import json # 设置请求头信息 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'} # 定义获取歌曲信息的函数 def get_song_info(song_id): """ 获取指定歌曲的信息 :param song_id: 歌曲ID :return: 歌曲信息字典 """ url = 'https://api.imjad.cn/cloudmusic/?type=detail&id={}'.format(song_id) response = requests.get(url, headers=headers) song_info = json.loads(response.text) return song_info # 定义获取歌单信息的函数 def get_playlist_info(playlist_id): """ 获取指定歌单的信息 :param playlist_id: 歌单ID :return: 歌单信息字典 """ url = 'https://api.imjad.cn/cloudmusic/?type=playlist&id={}'.format(playlist_id) response = requests.get(url, headers=headers) playlist_info = json.loads(response.text) return playlist_info # 示例:获取歌单信息并输出歌曲名称歌手 playlist_id = '315577550' playlist_info = get_playlist_info(playlist_id) tracks = playlist_info['playlist']['tracks'] for track in tracks: song_id = track['id'] song_info = get_song_info(song_id) song_name = song_info['songs'][0]['name'] artists = song_info['songs'][0]['ar'] artist_names = [artist['name'] for artist in artists] print('歌曲:{},歌手:{}'.format(song_name, ', '.join(artist_names))) ``` 首先,我们定义了两个函数:`get_song_info`和`get_playlist_info`,分别用于获取单个歌曲歌单的信息。这里使用了一个第三方的网易云音乐API,可以直接传入歌曲歌单的ID来获取对应的信息。 然后,我们调用`get_playlist_info`函数获取指定歌单的信息,并从中提取出歌曲列表。对于每个歌曲,我们调用`get_song_info`函数获取其信息,并从中提取出歌曲名称歌手信息。最后,我们将这些信息输出。 需要注意的是,我们在请求时设置了请求头信息,这是为了模拟浏览器的请求,避免被网站识别为爬虫而被屏蔽。此外,我们还使用了`json`模块将返回的JSON字符串转换为Python字典,方便处理和提取信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值