精易论坛

标题: 某我音乐爬虫下载 [打印本页]

作者: Mouth    时间: 2023-5-25 13:43
标题: 某我音乐爬虫下载
某我音乐爬虫用户故事
作为一位热爱听歌的用户,我经常会在各大音乐网站和视频网站听最新流行的歌曲。但是这些网站的歌曲和歌词都是在线的,无法下载到本地。我想要一个应用程序,能够帮我爬取这些网站上的流行歌曲和歌词,下载到本地,这样我就可以把歌曲和歌词存入U盘,在车上听和唱了。
请求头
[Python] 纯文本查看 复制代码
headers = {
    'Host': 'www.kuwo.cn',
    'Referer': 'http://www.kuwo.cn/rankList',
    'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko)'
                  ' Chrome/76.0.3809.87 Safari/537.36',
    'Cookie': XXX
    'csrf': 'XXx'
}

获取抖音排行版的歌曲
[Python] 纯文本查看 复制代码
def get_music_list(page=1):
    """获取抖音排行版的歌曲"""
    url = 'http://www.kuwo.cn/api/www/bang/bang/musicList'
    param = {
        "bangId": BANGID,
        "pn": page,
        "rn": "20",
        "httpsStatus": "1",
        "reqId": "2d9ff400-cf89-11ed-90ce-6f5d3667ff22"
    }
    response = requests.get(url=url, headers=headers, params=param)
    if response.status_code == 200:
        res = response.json()
        if res['code'] == 200:
            music_list = res['data']['musicList']
    return music_list

获取音乐下载地址
[Python] 纯文本查看 复制代码
def get_music_url(music_list):
    """获取音乐下载地址"""
    uuid_par = uuid.uuid1()
    # 获取时间戳,毫秒级别
    # t = time.time()
    # now_time = int(round(t * 1000))
    url_list = []
    name_list = []
    for music in music_list:
        name = music['name']
        rid = music['rid']
        param = {
            'mid': rid,
            'type': 'convert_url3',
            'httpsStatus': 1,
            'reqId': uuid_par,
        }
        music_info_url = " http://www.kuwo.cn/api/v1/www/music/playUrl"
        response = requests.get(url=music_info_url, params=param)
        try:
            if response.status_code == 200:
                # print(response.json())
                down_url = response.json()['data']['url']
                url_list.append(down_url)
                name_list.append(name)
        except Exception as e:
            print(f"error:<{name}>", e)
    return url_list, name_list

下载音乐
[Python] 纯文本查看 复制代码
def save_music(url_list, name_list):
    """下载音乐"""
    path = 'D:\\Music\\抖音'
    # 如果不存在目录,创建目录
    if not os.path.exists(path):
        os.makedirs(path)
    for i in range(1, len(url_list)):
        name = name_list
        music = requests.get(url=url_list, verify=False)
        if music.status_code == 200:
            with open('{}/{}.mp3'.format(path, name), 'wb') as f:
                f.write(music.content)
                print('{}:Download successful: {}.mp3'.format(i, name))
        else:
            print('下载歌曲失败')

domain
[Python] 纯文本查看 复制代码
def do_main():
    for i in range(1, 2):
        music_list = get_music_list()
        url_list, name_list = get_music_url(music_list)
        save_music(url_list, name_list)



作者: yuzhong    时间: 2023-11-6 04:36
感谢分享,很给力!~
作者: Anleton    时间: 2023-11-7 20:00
我就是一学生,过来学习的
作者: ergouzi8949    时间: 2024-1-26 10:36
感谢分享,很给力!~
作者: zc97    时间: 2024-5-25 20:16
感谢分享,很给力!~
作者: shaoxing0117    时间: 2024-6-26 20:47
        支持开源~!感谢分享
作者: pq9999    时间: 2024-7-9 09:26
    支持开源~!感谢分享
作者: yuzhong    时间: 2025-5-5 00:46
11111111111111111111111111111111
作者: 铭焱    时间: 2025-5-31 00:58
支持开源~!感谢分享
作者: zl520    时间: 2025-6-4 10:30
我有个破J版的,可以无限下载




欢迎光临 精易论坛 (https://125.confly.eu.org/) Powered by Discuz! X3.4