这是一个python练习,经过这个练习,咱们能够了解:python
在network分析中,快速浏览一下全部的http请求,查看响应的结果,很快就能找到mysql
在请求中,咱们发现了一个请求/revision/album/v1/getTracksList?albumId=18521227&pageNum=1,对就它了git
结合页面的状况,还有响应的结果,咱们应该能猜到:albumId应该就是专辑ID,而pageNum应该就是页面了,咱们验证一下sql
没有错,这个就是列表信息的请求url了。json响应结果中,咱们找比较重要的信息:trackId-音频ID,title-音频标题,url-音频播放地址数据库
列表信息来源应该搞清楚了,咱们接着看音频播放的时候是否能找到音频来源?json
这个请求响应结果里面的src就是音频地址了api
获取专辑列表方法浏览器
# 获取专辑列表
# album_id 专辑ID
# page_num 页码
def get_track_list(album_id, page_num):
url = "https://www.ximalaya.com/revision/album/v1/getTracksList?albumId=" + str(album_id) + "&pageNum=" + str(
page_num)
track_list = []
resp = requests.get(url, headers=header)
result = resp.json()
if result['ret'] == 200:
tracks = result['data']['tracks']
for tack in tracks:
track_list.append(
{'index': tack['index'], 'play_count': tack['playCount'], 'duration': tack['duration'], 'trackId': tack['trackId'], 'title': tack['title'],
'url': tack['url']})
# 加入字典(暂时没有使用)
track_map[tack['trackId']] = tack['title']
return track_list
复制代码
获取单个音频信息方法bash
# 获取音频地址
def get_track_url(track_id):
url = "https://www.ximalaya.com/revision/play/v1/audio?id=" + str(track_id) + "&ptype=1"
resp = requests.get(url, headers=header)
result = resp.json()
if result['ret'] == 200:
track_audio_play = result['data']['src']
if len(track_audio_play) > 0:
return track_audio_play
复制代码
保存http音频文件信息到本地app
#下载音频文件
def download_track_audio(url, file):
resp = requests.get(url, headers=header, stream=True)
with open(file, "wb") as f:
for data in resp.iter_content(chunk_size=1024):
if data:
f.write(data)
复制代码
例子运行&保存信息到数据库
try:
dir = "H:/Temp"
# 链接 mysql 的方法:connect('ip','user','password','dbname')
con = mdb.connect(host='127.0.0.1', user='root', passwd='123456', db='py_demo', use_unicode=True, charset="utf8")
# 全部的查询,都在链接 con 的一个模块 cursor 上面运行的
cur = con.cursor()
# 执行一个查询
# cur.execute("SELECT VERSION()")
# 取得上个查询的结果,是单个结果
# data = cur.fetchone()
track_list = get_track_list(18521227, 1)
sql = """insert into track_info_demo(id,trackId,title,play_count,duration,url,file_path) values(%s,%s,%s,%s,%s,%s,%s)"""
for track_info in track_list:
# 下载
track_url = get_track_url(track_info.get('trackId'))
file_path = ""
if track_url:
# 扩展名
file_name = track_url[track_url.rindex('/'):]
# 文件名路径
file_path = dir + file_name
# 下载
download_track_audio(track_url, file_path)
# values.append(track_info.get('index'))
# values.append(track_info.get('trackId'))
values = [track_info.get('index'), track_info.get('trackId'), track_info.get('title'), track_info.get('playCount'), track_info.get('duration'),
track_info.get('url'), file_path]
cur.execute(sql, values)
con.commit()
finally:
if con:
# 不管如何,链接记得关闭
con.close()
复制代码
结果
数据库保存信息
文件信息