1. 程式人生 > 實用技巧 >Python爬蟲實戰教學:網易雲音樂爬取你喜歡得歌曲

Python爬蟲實戰教學:網易雲音樂爬取你喜歡得歌曲

前言

本文的文字及圖片來源於網路,僅供學習、交流使用,不具有任何商業用途,如有問題請及時聯絡我們以作處理。

( 想要學習Python?Python學習交流群:1039649593,滿足你的需求,資料都已經上傳群檔案流,可以自行下載!還有海量最新2020python學習資料。 )

本次目標

爬取網易雲音樂
https://music.163.com/

環境

  • python 3.6
  • pycharm

爬蟲程式碼

匯入工具

import requests
import re

請求網站、解析網站資料

def get_music_url(music_id, music_title):
    url 
= 'https://api.zhuolin.wang/api.php' headers = { 'Accept': '*/*', 'Accept-Encoding': 'gzip, deflate, br', 'Accept-Language': 'zh-CN,zh;q=0.9', 'Cache-Control': 'no-cache', 'Connection': 'keep-alive', 'Cookie': 'UM_distinctid=175aca5b31d39e-06d658eceb014a-3962420d-1fa400-175aca5b31e92e
', 'Host': 'api.zhuolin.wang', 'Pragma': 'no-cache', 'Referer': 'https://music.zhuolin.wang/', 'Sec-Fetch-Dest': 'script', 'Sec-Fetch-Mode': 'no-cors', 'Sec-Fetch-Site': 'same-site', 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36
', } params = { 'callback': 'jQuery111305698848623906863_1604919341715', 'types': 'url', 'id': '{}'.format(music_id), 'source': 'netease', '_': '1604919341751', } response = requests.get(url=url, params=params, headers=headers) html_data = response.text if music_url == '': print('無音訊下載連結') def music_id(): url = 'https://music.163.com/discover/toplist' headers = { 'user-agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/81.0.4044.138 Safari/537.36' } response = requests.get(url=url, headers=headers) lis = re.findall('<li><a href="(.*?)">(.*?)</a></li>', response.text, re.S)[0:100] for i in lis: music_id = i[0].split('id=')[-1] title = i[1] pattern = re.compile(r"[\/\\\:\*\?\"\<\>\|]") # '/ \ : * ? " < > |' music_title = re.sub(pattern, "_", title) # 替換為下劃線 get_music_url(music_id, music_title)

儲存資料

   else:
        path = '儲存地址\\' + music_title + '.mp3'
        response = requests.get(url=music_url)
        with open(path, mode='wb') as f:
            f.write(response.content)
            print(music_title, music_url)

執行程式碼,結果如下圖