写Python代码,爬取批量QQ音乐的例子
时间: 2023-11-21 22:46:05 浏览: 76
可以的,以下是一段示例代码,可以批量爬取指定歌手的歌曲:
```python
import requests
import os
# 要爬取的歌手名字
artist_name = "周杰伦"
# 搜索的URL
search_url = "https://c.y.qq.com/soso/fcgi-bin/client_search_cp"
# 下载的URL
download_url = "https://u.y.qq.com/cgi-bin/musicu.fcg"
# URL参数
search_params = {
"p": 1, # 页数
"n": 100, # 每页数量
"w": artist_name, # 歌手名字
}
# 请求头
headers = {
"referer": "https://y.qq.com/portal/search.html",
"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",
}
# 发送搜索请求
resp = requests.get(search_url, params=search_params, headers=headers)
# 提取歌曲信息
songs = resp.json()["data"]["song"]["list"]
# 遍历歌曲信息
for song in songs:
# 歌曲ID
songmid = song["mid"]
# 下载参数
download_params = {
"data": '{\
"req_0":\
{\
"module":"vkey.GetVkeyServer",\
"method":"CgiGetVkey",\
"param":\
{\
"guid":"1276158090",\
"songmid":["'+songmid+'"],\
"songtype":[0],\
"uin":"0",\
"loginflag":1,\
"platform":"20"\
}\
},\
"comm":\
{\
"uin":0,\
"format":"json",\
"ct":20,\
"cv":474,\
"needNewCode":0,\
"platform":"20"\
}\
}'
}
# 发送下载请求
resp = requests.get(download_url, params=download_params, headers=headers)
# 提取下载链接
download_link = resp.json()["req_0"]["data"]["midurlinfo"][0]["purl"]
# 下载歌曲
resp = requests.get("http://dl.stream.qqmusic.qq.com/" + download_link)
with open(f"{song['name']}.mp3", "wb") as f:
f.write(resp.content)
print("下载完成!")
```
以上代码可以通过爬虫技术批量爬取指定歌手的歌曲,并将歌曲下载到本地。注意,此代码仅供学习和参考,请勿商用和非法传播!
阅读全文