代码部分
import osimport reimport jsonimport requestsfrom lxml import etreedef download_songs(url=None):if url is None:url = 'https://music.163.com/#/playlist?id=2384642500'url = url.replace('/#', '').replace('https', 'http') # 对字符串进行去空格和转协议处理# 网易云音乐外链url接口:http://music.163.com/song/media/outer/url?id=xxxxout_link = 'http://music.163.com/song/media/outer/url?id='# 请求头headers = {'User-Agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_13_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/68.0.3440.106 Safari/537.36','Referer': 'https://music.163.com/','Host': 'music.163.com'}# 请求页面的源码res = requests.get(url=url, headers=headers).texttree = etree.HTML(res)# 音乐列表song_list = tree.xpath('//ul[@class="f-hide"]/li/a')
由于篇幅限制,完整代码在下方领取

代码用法
直接把代码复制到pycharm运行即可。
如果缺少lxml库,则需要使用指令pip install lxml先安装该模块。
功能
可以把歌单下的音乐都下载下来。
演示截图
例如爬取歌单下面的音乐

其中部分音乐是vip音乐。

运行后即可下载完全部音乐








