继续创造,加速生长!这是我参加「掘金日新方案 4 月更文应战」的第12天,点击检查活动详情
成年人的国际真不容易啊
总是哀痛大于欢欣
爱情由于懵懂而高兴
却走进了复杂和困惑的婚姻
前语
我最近喜爱去听情感类的节目,比如说,婚姻类,我可能老了吧。我就想着怎样把音乐下载下来了,保存到手机上,便利咱们业余时间去听。
发送恳求
首要,咱们要确认咱们的目标网址,咱们想要获取到每一个音频的地址。
咱们发送恳求,获取网页源代码。咱们相信咱们这儿的代码都会写了。
url = 'https://www.ximalaya.com/album/37453303'
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/111.0.0.0 Safari/537.36',
}
res = requests.get(url,headers=headers)
requests
是 Python 的一个内置模块,用于发送 HTTP 恳求。在这个比如中,咱们运用requests.get()
函数向https://www.ximalaya.com/album/37453303
发送一个 GET 恳求,并将恳求头和呼应体作为参数传递给函数。
获取数据
info_list = re.findall('"tracks":[(.*?)]', res.text)[1]
print(info_list)
re.findall()
函数用于在字符串中查找所有匹配的子字符串。在这个比如中,咱们运用re.findall()
函数查找了呼应体中的tracks
字符串,并运用切片[1]
取出了子字符串列表。
子字符串列表中的第一个元素就是咱们要找的tracks
字符串。咱们将其存储在info_list
变量中,并运用print()
函数输出。
咱们发现,咱们想要的数据,就在咱们匹配的内容中。里面包含了每一个音乐的标题和其id,咱们接下来把这个获取下来。
留意,这儿,不是json数据,所以,咱们只能正则去匹配。
解析数据
咱们经过比照url发现,咱们只需要拿到uid,就可以直接访问到音频。这儿就不多解释。
audio = f'https://www.ximalaya.com/revision/play/v1/audio?id={trackId}&ptype=1'
咱们只需要把trackID换掉,就可以了。恳求上面的url,就可以拿到音频的地址。接下来,咱们写代码。
for trackId, title in zip(trackIds, titles):
audio = f'https://www.ximalaya.com/revision/play/v1/audio?id={trackId}&ptype=1'
print(audio)
audio_res = requests.get(audio, headers=headers)
audio_url = audio_res.json()['data']['src']
print(audio_url)
zip()
函数用于将两个列表合并成一个列表。在这个比如中,咱们运用zip()
函数将trackIds
和titles
两个列表合并成一个列表,并将其存储在trackIds
变量中。
然后,咱们将trackId
和title
转换为字符串格式,并将其存储在audio
变量中。
接下来,咱们运用requests.get()
函数向audio
发送一个 GET 恳求,并将恳求头和呼应体作为参数传递给函数。
最后,咱们运用json()
办法将呼应体中的data
字段转换为 JSON 格式,并运用['data']['src']
取出了src
属性,即audio_url
的值,并将其存储在audio_url
变量中。
保存数据
music_content = requests.get(audio_url, headers=headers).content
with open('music//' + f'{title}' + '.mp3', mode='wb') as filename:
filename.write(music_content)
print(title, '保存成功')
接下来,咱们恳求这个网页,保存二进制到本地。with open()
语句用于主动封闭文件,保证文件在运用完毕后被正确封闭。在这个比如中,咱们运用with open()
语句翻开一个名为music//
+title
+ .mp3
的文件,并将其保存到变量filename
中。
然后,咱们运用write()
办法将音频内容写入文件中。
总结
这是一个关于如何下载音乐并保存到手机的Python代码实战。咱们首要确认咱们的目标网址,然后运用requests.get()
函数向该网址发送一个 GET 恳求,并将恳求头和呼应体作为参数传递给函数。
在恳求成功后,咱们运用json()
办法将呼应体中的data
字段转换为 JSON 格式,并运用['data']['src']
取出了src
属性,即audio_url
的值,并将其存储在audio_url
变量中。
咱们恳求网页,保存二进制,就可以保存了。