python爱好者. 发表于 2022-8-14 19:51:11

一个能让你免登录下载酷我里的音乐的程序 V2.0(有鱼币)

上一个版本:https://fishc.com.cn/thread-216571-1-1.html


此版本更新了N处:{:10_327:}
1.可以下载 vip 才能下载的歌曲了!{:10_298:}
2.添加了 "合法化非法文件名" 的代码{:10_256:}
3.大幅提高了防报错能力{:10_305:}
4.合并了几个函数,并精简了代码{:10_335:}
5.添加了翻页功能{:10_323:}

废话不多说,上代码:
import urllib.request
import urllib.parse
import json
import os

def down_load_music(music_address,down_load_address,information_list): #下载歌曲
    #获取音乐名
    music_name = get_right_music_name(information_list)
   
    #创建文件
    with open(f"{down_load_address}\\{music_name}.mp3","w") as f:
      pass
   
    #写入歌曲
    with open(f"{down_load_address}\\{music_name}.mp3","wb") as f:
      music = urllib.request.urlopen(music_address).read()
      f.write(music)

def get_right_music_name(information_list): #合法化歌曲名
    #初始变量
    music_name = information_list #歌曲名
    characters = ['/', '\\', ':', '*', '?', '"', '<', '>', '|'] #非法字符

    for each in characters:
      if each in music_name: #含此非法字符
            music_name = music_name.replace(each,"") #去除非法字符

    return music_name

def get_music_address(information_list,music_num,second_headrs_words): #获取音乐地址
    #获取此歌信息
    information_list = information_list

    #初始变量
    url = f"http://www.kuwo.cn/api/v1/www/music/playUrl?mid={information_list[-2]}&type=convert_url3&httpsStatus=1&reqId={information_list[-1]}" #歌曲网页地址
    second_headers = get_headers(second_headrs_words) #请求头2

    #获取数据
    req = urllib.request.Request(url,headers = second_headers)
    response = json.loads(urllib.request.urlopen(req).read().decode("utf8"))

    #返回结果
    music_address = response["data"]["url"]
    return music_address,information_list

def print_music_information(music_information): #打印歌曲信息
    information_list = [] #储存重要信息

    #初始变量
    reqId = music_information["reqId"] #作品vip信息
    i = 0 #迭代作品序列号

    #打印歌曲信息
    for each in music_information["data"]["list"]:
      #获取信息
      name = each["name"] #作品名字
      artist = each["artist"] #作者姓名
      album = each["album"] #作品专辑
      songTimeMinutes = each["songTimeMinutes"]
      rid = each["rid"] #作品id

      #储存信息
      information_list.extend([])
      
      #打印信息
      print(f"序号{i + 1}:/歌曲:{name}/,/歌手:{artist}/,/专辑:{album}/,/时长:{songTimeMinutes}/")
      
      i += 1

    return information_list

def get_music_information(music_name,music_page,first_headrs_words): #获取歌曲
    #初始变量
    url = f"http://www.kuwo.cn/api/www/search/searchMusicBykeyWord?key={urllib.parse.quote(music_name)}&pn={music_page}&rn=30&httpsStatus=1&reqId=1947b511-1ac6-11ed-abe0-e348db15d8b3"
    first_headers = get_headers(first_headrs_words) #请求头1

    #获取数据
    req = urllib.request.Request(url,headers = first_headers)
    response = json.loads(urllib.request.urlopen(req).read().decode("utf8"))
   
    return response

def get_headers(words): #生成请求头
    headers = {each:each for each in } #转换为字典
   
    return headers

def first_try(music_name,music_page,first_headers_words):
    try:
      music_information = get_music_information(music_name,music_page,first_headers_words)
      return music_information
      
    except urllib.error.HTTPError as reason:
      if reason == "HTTP Error 504: Gateway Timeout": #暂时性网络连接失败
            #提示
            print("网络连接失败,正在重试中,请耐心等待!")

            #重试
            first_try()   

def second_try(music_address,down_load_address,information_list,music_name,first_headers_words):
    try:
      down_load_music(music_address,down_load_address,information_list)

    except PermissionError as reason:
      while " Permission denied:" in reason: #没有访问权限
            down_load_address = input("抱歉,我们没有在此文件夹中创建文件的权力,请换个位置,如:'C:\\test':")
            down_load_music(music_address,down_load_address,information_list)

def third_try(music_name,start_page,first_headers_words):
    #获取歌曲所在页数(有概率报错)(已解决)
    music_page,information_list = get_music_page(get_music_pages(music_name,start_page,first_headers_words),music_name,first_headers_words)

    while music_page == -1: #查无此歌
      music_name = input("抱歉,未查询到此歌,请重新输入歌曲名称:")
      music_page,information_list = get_music_page(get_music_pages(music_name,start_page,first_headers_words),music_name,first_headers_words)

    return music_page,information_list

def fourth_try():
    try:
      #让用户选择要下载的歌所对应的序列号
      music_num = int(input("请输入歌曲序列号:"))

      while not(0 < music_num < 31): #范围超出 1 到 30
            music_num = int(input("序列号超出最大值,请重新输入歌曲序列号:"))

      #返回结果
      return music_num

    except ValueError as reason:
      if "invalid literal for int() with base 10:" in reason: #序列号非数字类型
            fourth_try()

def get_music_page(pages,music_name,first_headers_words): #获取歌曲所在页数
    if pages == 0: #没有此歌
      return -1,-1
   
    else:
      #初始变量
      page = 0 #歌曲所在页数

      for i in range(1,pages + 1):
            #获取歌曲信息(有概率报错)(已解决)
            music_information = first_try(music_name,i,first_headers_words)
            
            #打印歌曲信息
            information_list = print_music_information(music_information)

            #让用户选择是否继续获取歌曲信息
            still_display = input("请输入是否切换下一页(回答:'是'或'否'):")

            #执行用户指令
            if still_display == "否": #停止展示歌曲信息
                page = i
                break
            
      else: #达到最后一页
            print("抱歉,这已经是最后一页了!")

      #返回结果
      return page,information_list

def get_music_pages(music_name,start_page,first_headers_words): #获取页面总页数
    #获取歌曲信息(有概率报错)(已解决)
    music_information = first_try(music_name,start_page,first_headers_words)

    #返回结果
    pages = int(music_information["data"]["total"]) // 30 #总页数
    return pages

def main():
    #用户信息
    music_name = input("请输入歌曲名称:")
   
    #初始变量
    first_headers_words = """Accept: application/json, text/plain, */*
Accept-Language: zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6
Connection: keep-alive
Cookie: _ga=GA1.2.38866944.1643424882; BusinessId={"std_plat":404,"std_dev":"d2b0d6c5-27ce-4b06-bf62-1e19b3ad6f84","std_imei":"d2b0d6c5-27ce-4b06-bf62-1e19b3ad6f84"}; _gid=GA1.2.432698325.1660354553; Hm_lvt_cdb524f42f0ce19b169a8071123a4797=1660254093,1660354553,1660356822,1660366722; Hm_lpvt_cdb524f42f0ce19b169a8071123a4797=1660367192; kw_token=UX6Z894LRHB; _gat=1
Host: www.kuwo.cn
Referer: http://www.kuwo.cn/search/list?key=%E5%AD%A4%E5%8B%87%E8%80%85
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/104.0.5112.81 Safari/537.36 Edg/104.0.1293.47
csrf: UX6Z894LRHB""" #请求头1

    second_headers_words = """Accept: application/json, text/plain, */*
Accept-Language: zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6
Connection: keep-alive
Cookie: _ga=GA1.2.38866944.1643424882; BusinessId={"std_plat":404,"std_dev":"d2b0d6c5-27ce-4b06-bf62-1e19b3ad6f84","std_imei":"d2b0d6c5-27ce-4b06-bf62-1e19b3ad6f84"}; _gid=GA1.2.432698325.1660354553; Hm_lvt_cdb524f42f0ce19b169a8071123a4797=1660254093,1660354553,1660356822,1660366722; kw_token=DQ089P4PGZG; Hm_lpvt_cdb524f42f0ce19b169a8071123a4797=1660374530; _gat=1
Host: www.kuwo.cn
Referer: http://www.kuwo.cn/play_detail/198554068
User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/104.0.5112.81 Safari/537.36 Edg/104.0.1293.47""" #请求头2

    start_page = 1 #起始页

    #获取歌曲所在页数(有概率报错)(已解决)
    music_page,information_list = third_try(music_name,start_page,first_headers_words)

    #让用户选择要下载的歌所对应的序列号
    music_num = fourth_try()

    #获取歌曲地址
    music_address,information_list = get_music_address(information_list,music_num,second_headers_words)

    #让用户选择要将歌曲下载在哪里
    down_load_address = input(r"请输入存放歌曲的位置(文件夹),如:'C:\\test':")

    #下载歌曲(有概率报错)
    second_try(music_address,down_load_address,information_list,music_name,first_headers_words)


if __name__ == "__main__":
    #初始变量
    running = True #程序是否继续执行

    #主循环
    while running:
      main()


      




注意:
1.此程序并非与这个作品的交互过程相同,且原理也不一样 :{:10_334:}
一个(大佬@青出于蓝的)是需要:用户自己打开酷我并手动传入网页地址(url)参数的(注意:此处无贬义{:10_297:},因为一个追求的是小巧轻便;另一个则是"懒"),
一个(我的)是只需要在程序里操作的,
两者没有对比意义(因为原理不一样)
2.此程序创意来自大佬@青出于蓝,感谢!

最后附上一张程序效果展示图:

python爱好者. 发表于 2022-8-14 19:52:33

本帖最后由 python爱好者. 于 2022-8-14 19:57 编辑

@isdkz @青出于蓝 @shiyouroc @ckblt @柿子饼同学
来看看...

柿子饼同学 发表于 2022-8-14 20:39:02

python爱好者. 发表于 2022-8-14 19:52
@isdkz @青出于蓝 @shiyouroc @ckblt @柿子饼同学
来看看...

来啦
高 , 高啊{:10_256:}

一点点儿 发表于 2022-8-14 21:18:09

可以下vip了,太赞了{:5_106:}

一点点儿 发表于 2022-8-14 21:18:42

感谢大佬的分享{:10_279:}

yeah_again 发表于 2022-8-14 21:30:51

666

hornwong 发表于 2022-8-14 22:18:35

感谢分享!

hornwong 发表于 2022-8-14 22:19:13

{:5_108:}

hornwong 发表于 2022-8-14 22:20:04

感谢分享!

tiancai132mm 发表于 2022-8-14 22:39:48

代码好牛逼啊,谢谢分享

white_slacker 发表于 2022-8-15 09:27:42

{:10_254:}

myqf123 发表于 2022-8-15 11:07:47

赞一个

编程追风梦 发表于 2022-8-15 11:09:42

牛,太牛了

取昵称好难哟 发表于 2022-8-15 11:32:44

感谢分享!

取昵称好难哟 发表于 2022-8-15 11:33:16

{:10_254:}

desc 发表于 2022-8-15 13:24:31

{:10_323:}

desc 发表于 2022-8-15 13:25:10

{:10_275:}

香蕉那个不拿拿 发表于 2022-8-15 13:47:49

感谢大佬的分享

leletatann 发表于 2022-8-15 14:34:13

感谢

编程追风梦 发表于 2022-8-15 16:04:31

牛啊
页: [1] 2 3 4
查看完整版本: 一个能让你免登录下载酷我里的音乐的程序 V2.0(有鱼币)