python爬千千音樂

模擬瀏覽器,訪問互聯網資源,根據所寫的規則,下載所需的音樂數據!html

源代碼查看:在更多工具裏的開發者工具(shift+ctrl+I 或f12)正則表達式

在谷歌瀏覽器中登入千千音樂 http://music.taihe.comjson

在pycharm寫代碼api

在Terminal中輸入pip install requests回車即安裝requests瀏覽器

程序代碼:數據結構

import requests
import re工具


#第一步 獲取歌曲ids
search_api ='http://music.taihe.com/search'
#搜索的關鍵字,傳遞參數,經過字典構造
keyword = {'key':'阿蘭'}
#發送請求
#get請求 params 是傳遞的get參數
response=requests.get(search_api,params=keyword)
#取出html的源碼
response.encoding='utf-8'
html = response.text
#經過正則表達式獲取id
ids=re.findall(r'{"id":"(\d+)"',html)
print(ids)
#第二步 獲取歌曲的信息
mp3_info_api ='http://play.taihe.com/data/music/songlink'
data ={
'songIds': ','.join(ids),
'hq': 0,
'type': 'm4a,mp3',
'rate': '',
'pt': 0,
'flag': -1,
's2p': -1,
'prerate': -1,
'bwt': -1,
'dur': -1,
'bat': -1,
'bp': -1,
'pos': -1,
'auto': -1
}
#data就是post的參數
res = requests.post(mp3_info_api,data=data)
#返回的數據是json格式 直接調用json方法,轉成字典
info = res.json()post

#第三步 去下載歌曲
#根據數據的結構,獲取歌曲的信息
song_info =info['data']['songList']
#循環
for song in song_info:
#根據數據結構獲取信息
#歌名
song_name = song['songName']
#mp3地址
song_link = song['songLink']
#格式
for_mat = song['format']
#歌詞地址
lrclink = song['lrcLink']
# print(song_name,song_link,for_mat,lrclink)
#下載mp3
if song_link:#有可能沒有地址
song_res =requests.get(song_link)
with open('%s.%s' % (song_name,for_mat),'wb')as f:
f.write(song_res.content)
print(song_link)spa

#下載歌詞
if lrclink:
lrc_response = requests.get(lrclink)
#寫文件
with open('%s,lrc' % song_name, 'w')as f:
f.write(lrc_response.text)orm

相關文章
相關標籤/搜索