在CSDN中,许多的听音乐代码是在用户已有一个音乐的MP3文件的情况下实现自动播放音频。接下来的代码可以实现你说什么音乐,他就放什么音乐。
首先我们来分析一下实现这个功能分为那几步骤。
用户输入歌名/歌手——>自动上网查询——>自动保存到pythonproject文件——>自动打开保存文件
这些步骤我们可以进行归纳为两部分:保存目标歌曲、打开保存文件
保存目标歌曲代码:
'''
自动下载QQ音乐制定歌手的歌曲到本地MP3
'''
import requests
import json
import os #插入几个包
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.90 Safari/537.36'
} #模拟
def get_music_info():
"""搜索功能"""
music_info_list = []
name = input('请输入歌手或歌曲:') #获取用户想要的内容
page = 1
num = 1
url = f'https://c.y.qq.com/soso/fcgi-bin/client_search_cp?p={page}&n={num}&w={name}'
response = requests.get(url, headers=headers).text # 获取到的是字符串
# 将response切分成json格式 类似字典 但是现在还是字符串
music_json = response[9:-1]
# json转字典
music_data = json.loads(music_json) # 转换成 字典
# print(music_data)
music_list = music_data['data']['song']['list']
for music in music_list:
music_name = music['songname'] # 歌曲的名字
singer_name = music['singer'][0]['name'] # 歌手的名字
songmid = music['songmid']
music_info_list.append((music_name, singer_name, songmid))
return music_info_list
def get_purl(music_info_list):
"""单首歌曲地址拼接"""
music_data = []
for music in music_info_list:
music_name = music[0]
singer_name = music[1]
songmid = music[2]
url = 'https://u.y.qq.com/cgi-bin/musicu.fcg?data={"req":{"module":"CDN.SrfCdnDispatchServer","method":"GetCdnDispatch","param":{"guid":"8846039534","calltype":0,"userip":""}},"req_0":{"module":"vkey.GetVkeyServer","method":"CgiGetVkey","param":{"guid":"8846039534","songmid":["%s"],"songtype":[0],"uin":"1152921504784213523","loginflag":1,"platform":"20"}},"comm":{"uin":"1152921504784213523","format":"json","ct":24,"cv":0}}' % songmid
response = requests.get(url, headers=headers).json()
purl = response['req_0']['data']['midurlinfo'][0]['purl']
full_media_url = 'http://dl.stream.qqmusic.qq.com/' + purl
music_data.append(
{
'music_name': music_name,
'singer_name': singer_name,
'full_media_url': full_media_url
})
return music_data
def save_music_mp3(music_data):
"""下载歌曲"""
if not os.path.exists('歌曲下载'):
os.mkdir('歌曲下载')
for music in music_data:
music_name = music['music_name']
singer_name = music['singer_name']
full_url = music['full_media_url']
music_response = requests.get(full_url, headers=headers).content #歌曲下载
with open('歌曲下载/%s-%s.mp3' % (music_name, singer_name), 'wb')as fp:
fp.write(music_response)
print('[%s]保存成功!' % music_name) #成功反馈
if __name__ == '__main__':
music_info_list = get_music_info()
music_data = get_purl(music_info_list)
save_music_mp3(music_data)
通过这段代码可以把音乐保存到一个叫“歌曲下载” 的文件中
那么如何把保存的文件自动打开呢?我们可以用Chromedriver打开
打开保存歌曲代码:
for music in music_data:
music_name = music['music_name']
singer_name = music['singer_name']
x = (music_name + "-" + singer_name)
print(x) #变量x就是我们刚刚那段代码保存下来的音乐名
# coding = utf-8
from time import sleep
import os
from selenium import webdriver
browser = webdriver.Chrome()
# browser.get('http://www.baidu.com/')
browser.get('file:///D:/PycharmProjects/pythonProject2/歌曲下载/'+ x + ".mp3") #路径可以自行修改
login_form = browser.find_element_by_id('auto').click()
# 等待5秒
sleep(10 * 60)
# 退出
browser.quit()
最终代码:
'''
自动下载QQ音乐制定歌手的歌曲到本地MP3
'''
import requests
import json
import os
headers = {
'User-Agent': 'Mozilla/5.0 (Windows NT 6.1; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.90 Safari/537.36'
}
def get_music_info():
"""搜索功能"""
music_info_list = []
name = input('请输入歌手或歌曲:') #
page = 1
num = 1
url = f'https://c.y.qq.com/soso/fcgi-bin/client_search_cp?p={page}&n={num}&w={name}'
response = requests.get(url, headers=headers).text # 获取到的是字符串
# 将response切分成json格式 类似字典 但是现在还是字符串
music_json = response[9:-1]
# json转字典
music_data = json.loads(music_json) # 转换成 字典
# print(music_data)
music_list = music_data['data']['song']['list']
for music in music_list:
music_name = music['songname'] # 歌曲的名字
singer_name = music['singer'][0]['name'] # 歌手的名字
songmid = music['songmid']
music_info_list.append((music_name, singer_name, songmid))
return music_info_list
def get_purl(music_info_list):
"""单首歌曲地址拼接"""
music_data = []
for music in music_info_list:
music_name = music[0]
singer_name = music[1]
songmid = music[2]
url = 'https://u.y.qq.com/cgi-bin/musicu.fcg?data={"req":{"module":"CDN.SrfCdnDispatchServer","method":"GetCdnDispatch","param":{"guid":"8846039534","calltype":0,"userip":""}},"req_0":{"module":"vkey.GetVkeyServer","method":"CgiGetVkey","param":{"guid":"8846039534","songmid":["%s"],"songtype":[0],"uin":"1152921504784213523","loginflag":1,"platform":"20"}},"comm":{"uin":"1152921504784213523","format":"json","ct":24,"cv":0}}' % songmid
response = requests.get(url, headers=headers).json()
purl = response['req_0']['data']['midurlinfo'][0]['purl']
full_media_url = 'http://dl.stream.qqmusic.qq.com/' + purl
music_data.append(
{
'music_name': music_name,
'singer_name': singer_name,
'full_media_url': full_media_url
})
return music_data
def save_music_mp3(music_data):
"""下载歌曲"""
if not os.path.exists('歌曲下载'):
os.mkdir('歌曲下载')
for music in music_data:
music_name = music['music_name']
singer_name = music['singer_name']
full_url = music['full_media_url']
music_response = requests.get(full_url, headers=headers).content
with open('歌曲下载/%s-%s.mp3' % (music_name, singer_name), 'wb')as fp:
fp.write(music_response)
print('[%s]保存成功!' % music_name)
if __name__ == '__main__':
music_info_list = get_music_info()
music_data = get_purl(music_info_list)
save_music_mp3(music_data)
for music in music_data:
music_name = music['music_name']
singer_name = music['singer_name']
x = (music_name + "-" + singer_name)
print(x)
# coding = utf-8
from time import sleep
import os
from selenium import webdriver
browser = webdriver.Chrome()
# browser.get('http://www.baidu.com/')
browser.get('file:///D:/PycharmProjects/pythonProject2/歌曲下载/'+ x + ".mp3")
login_form = browser.find_element_by_id('auto').click()
# 等待5秒
sleep(10 * 60)
# 退出
browser.quit()
以上代码就可以实现自动播放音乐这个功能了