用python制作個音樂下載器
前言
某個夜深人靜的夜晚,我打開了自己的文件夾,發(fā)現(xiàn)了自己寫了許多似乎很無聊的代碼。于是乎,一個想法油然而生:“生活已經(jīng)很無聊了,不如再無聊一點叭”。
說干就干,那就開一個專題,我們稱之為kimol君的無聊小發(fā)明。
妙…啊~~~
直奔主題!本文主題是用python做一個音樂下載器(MusicLover),直接上圖:

想必看到這里,各位看官的腦海中已經(jīng)腦補出各種JS解密,參數(shù)分析等等讓初學(xué)者很頭疼的東東了。
然而,我并不打算這么干~(小聲嘀咕:“沒想到吧”)
本文很友好,也很適合初學(xué)者,而且功能依然強大!
欲知后事如何,客官您下面請~
一、技術(shù)實現(xiàn)
1.前人栽樹后人乘涼
為了避免繁雜的分析和破解過程,我不是直接沖去某云音樂、某Q音樂就是肝。通過在網(wǎng)上搜索我找到了一個網(wǎng)站。
通過測試,我發(fā)現(xiàn)它可以支持多個音樂平臺的音樂下載。既然如此,我何不在它的基礎(chǔ)上來進行開發(fā),正所謂“前人栽樹后人乘涼”,豈不妙哉?
2.后來者居上
通過瀏覽器自帶的工具(按F12),網(wǎng)絡(luò)攔截抓包后可知請求為POST,且只有4個參數(shù):

那么,通過requests庫便能很好的實現(xiàn)這個請求。
# 定義相關(guān)參數(shù)
url = 'https://music.sonimei.cn' # 下載接口
headers = {'User-Agent':'Mozilla/5.0 (Windows NT 6.3; Win64; x64; rv:81.0) Gecko/20100101 Firefox/81.0',
'Accept':'application/json, text/javascript, */*; q=0.01',
'Accept-Language':'zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2',
'Accept-Encoding':'gzip, deflate, br',
'Content-Type':'application/x-www-form-urlencoded; charset=UTF-8',
'X-Requested-With':'XMLHttpRequest',
'Content-Length':'53',
'Connection':'keep-alive'} # 請求頭
data = {'input':'林俊杰',
'filter':'name',
'type':'qq',
'page':1} # 請求參數(shù)
res = requests.post(url,headers=headers,data=data)
返回的數(shù)據(jù)為json格式,里面包括了音樂的名稱,作者以及音樂下載地址等信息。拿到地址之后,我們只需要將其下載到本地即可:
with open('test.m4a','wb') as f:
res = requests.get('http://dl.stream.qqmusic.qq.com/C1000045NGM43ZAUXG.m4a?fromtag=38')
f.write(res.content)
到這里,基本功能已經(jīng)實現(xiàn)了。我們站在前人的肩膀上,已經(jīng)實現(xiàn)了“后來者居上”。接下來只需要對它們進行一個包裝和集成就行。
3.集大成者
包裝的方式可以是各種各樣,這里提供我自己的一個思路,僅供參考,完整代碼如下:
# =============================================================================
# MusicLover by kimol
# =============================================================================
import os
import requests
from tqdm import tqdm
# 定義相關(guān)參數(shù)
url = 'https://music.sonimei.cn' # 下載接口
headers = {'User-Agent':'Mozilla/5.0 (Windows NT 6.3; Win64; x64; rv:81.0) Gecko/20100101 Firefox/81.0',
'Accept':'application/json, text/javascript, */*; q=0.01',
'Accept-Language':'zh-CN,zh;q=0.8,zh-TW;q=0.7,zh-HK;q=0.5,en-US;q=0.3,en;q=0.2',
'Accept-Encoding':'gzip, deflate, br',
'Content-Type':'application/x-www-form-urlencoded; charset=UTF-8',
'X-Requested-With':'XMLHttpRequest',
'Content-Length':'53',
'Connection':'keep-alive'} # 請求頭
data = {'input':'',
'filter':'name',
'type':'qq',
'page':1} # 請求參數(shù)
savePath = './musics' # 音樂保存目錄
# 檢查存儲路徑是否存在
if not os.path.exists(savePath):
os.mkdir(savePath)
# 歡迎界面
welcome = '''
__ ___ _ __
/ |/ /_ _______(_)____/ / ____ _ _____ _____
/ /|_/ / / / / ___/ / ___/ / / __ \ | / / _ \/ ___/
/ / / / /_/ (__ ) / /__/ /___/ /_/ / |/ / __/ /
/_/ /_/\__,_/____/_/\___/_____/\____/|___/\___/_/
'''
os.system('cls')
os.system('mode con cols=85 lines=25')
print(welcome)
# 循環(huán)開始
while True:
choice = input('>>>請輸入歌名(或歌手):')
if choice == 'quit':
print('歡迎再次使用~')
break
data['input'] = choice
res = requests.post(url,headers=headers,data=data)
d_json = res.json() # 搜索結(jié)果
musics = d_json['data']
if d_json['code'] != 200:
print('搜索結(jié)果為空,請重新輸入')
continue
else:
print('*'*45)
print('{0:{3}<4}{1:{3}<10}{2:{3}^10}{3}'.format('序號','歌名','作者',chr(12288)))
print('*'*45)
N = 1 # 序號
for m in musics:
print('{0:{3}<4}{1:{3}<10}{2:{3}^10}{3}'.format(N,m['title'],m['author'],chr(12288)))
N += 1
print('*'*45)
choice = input('>>>請選擇需要下載的歌曲:')
n = int(choice)
name = musics[n-1]['title'] # 歌名
url_download = musics[n-1]['url'] # 下載地址
bar = tqdm(range(1),ncols=60) # 進度條
for b in bar:
res = requests.get(url_download)
with open('%s/%s.m4a'%(savePath,name),'wb') as f:
f.write(res.content)
bar.set_description('下載中')
測試了一下,確實下載成功了:

二、后續(xù)改進
很顯然,我提供的代碼還只是一個很基礎(chǔ)的demo,還有很多地方可以去完善,比如:
- 美化界面,解決混合文字對齊的問題;
- 加入多線程,增加下載速度;
- 增加GUI,使操作更加便捷;
- 增加多選功能,實現(xiàn)一鍵下載。
可以做的東西實在太多太多了,我只是拋磚引玉,大家可以發(fā)揮自己的無窮的想象。
以上就是用python制作個音樂下載器的詳細內(nèi)容,更多關(guān)于python 音樂下載器的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Python利用re模塊實現(xiàn)簡易分詞(tokenization)
分詞(tokenization)任務(wù)是Python字符串處理中最為常見任務(wù)了。本文將利用re模塊實現(xiàn)簡易tokenizer,文中的示例代碼講解詳細,需要的可以參考一下2022-04-04
Python2.7實現(xiàn)多進程下開發(fā)多線程示例
這篇文章主要為大家詳細介紹了Python2.7實現(xiàn)多進程下開發(fā)多線程示例,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-05-05
在Python中使用NLTK庫實現(xiàn)對詞干的提取的教程
這篇文章主要介紹了在Python中使用NLTK庫實現(xiàn)對詞干的提取的教程,其中還用到了Pandas和IPython,需要的朋友可以參考下2015-04-04
Python創(chuàng)建模塊及模塊導(dǎo)入的方法
這篇文章主要介紹了Python創(chuàng)建模塊及模塊導(dǎo)入的方法,實例分析了模塊的定義、導(dǎo)入及模塊屬性的使用技巧,并附帶說明了包的概念與用法,需要的朋友可以參考下2015-05-05

