python音乐播放器开发,python爬取音乐代码

  python音乐播放器开发,python爬取音乐代码

  本文主要介绍了利用python网络爬虫实现个性化音乐播放器的详细示例代码和内容分析。有需要的朋友可以借鉴一下,希望能有所帮助。

  00-1010序分析开发组件的功能流程;基于python的个性化音乐下载器模块详解(1)前端模块(2)后端模块

  

目录

  目前很多人喜欢在业余时间听音乐,所以基于这个现象,我也花了几个小时完成了一个基于python的个性化音乐播放器,现在分享给大家。

  

前言

  Python3.5版本3.5以上都可以。

  Tkinter (python自己的图形用户界面开发模块)

  请求(爬网程序模块)

  Chrome浏览器

  等等

  

开发组件

  音乐下载器功能:

  (1)用户输入要下载的歌曲名或关键字。

  (2)程序获取用户输入的歌名关键词,并根据关键词向网站发起数据请求。

  (3)在分析返回的数据信息之后,程序将列表呈现给用户。

  (4)用户可以通过点击列表中显示的相应歌曲并点击下载来下载该歌曲。

  

功能

  

流程分析

  

基于python的个性化音乐下载器模块详细

  #创建一个窗口

  window=tkinter。Tk()

  #设置标题

  Window.title(音乐下载器,)

  #设置窗口大小和位置

  window.geometry(900x460 500 100 )

  #标签组件

  Lab=Label(window,text=请输入要下载的歌曲:,font=(中文正楷,15))

  # #标签定位

  lab.grid(行=0,列=0)

  #输入框组件

  Entry=Entry(window,font=(Lishu ,20),width=20)

  entry.grid(行=0,列=1)

  #搜索按钮

  Btn=Button(window,text= search ,font=(Lishu ,15),width=20,command=get _ music _ list)

  btn.grid(行=0,列=2)

  #列表框#可以设置多个选择,selectmode=MULTIPLE。

  Listbox=Listbox(window,font=(Lishu ,16),width=45,heigh=15)

  listbox.grid(row=1,columnspan=2)

  Listbox_1=Listbox(window,font=(Lishu ,16),width=35,heigh=15)

  listbox_1.grid(行=1,列=2)

  #下载按钮

  Btn_1=Button(window,text=开始下载,font=(Lishu ,15),command=get_music_url)

  btn_1.grid(行=2,列=0)

  #退出按钮

  Btn_2=Button(window,text=退出程序,font=(Lishu ,15),command=window.quit)

  btn_2.grid(行=2,列=2)

  #消息周期显示界面

  window.mainloop()

  代码中的Cammand用于绑定后端函数。

  此代码用于实现可视化和用户交互。这个我就不多说了。可以自己学习python自带的tkinter模块,效果如图。

  

(一)前端模块

  1.分析

  进入酷我音乐网站。

  我们先把这些歌名往下爬,然后添加到前端列表框。

  具体功能如下

  #获取音乐搜索列表的功能

  def get_music_list():

  #获取在前端搜索框中输入的内容

  name=entry.get()

  #清空列表框以在下次搜索时显示新歌曲列表。

  listbox.delete(0,

   END)

   #循环加载三页音乐

   for k in range(1,4):

   url = http://www.kuwo.cn/api/www/search/searchMusicBykeyWord?

   data = {

   key: name,

   pn: k,

   rn: 30,

   httpsStatus: 1,

   reqId: 161cbd51-cde1-11eb-bf58-bba623268fbb

   }

   response = requests.get(url=url,headers=headers,params=data,proxies=proxy).text

   dic_data = json.loads(response)

   list_data = dic_data[data][list]

   #listbox.delete(0,END)

   for i in list_data:

   music_name = i[name]+-+i[artist]

   #在列表框中插入音乐名称

   listbox.insert(END, music_name)

   music_id = i[rid]

   list_1.append(music_id)

  

  至此,音乐列表就添加到了列表框,注意我们将所有音乐的rid添加到了list_1的列表中,每个rid的索引跟列表框中的音乐名称索引是相对应的,这是实现点击相应歌曲下载的关键。然后我们需要实现点击下载的功能。

  具体函数如下

  

#解析音乐url的函数

  def get_music_url():

   index = listbox.curselection() #返回选取的索引,是一个元组

   for i in index:

   music_name = listbox.get(i)

   listbox_1.insert(END, music_name + 开始下载)

   url = http://www.kuwo.cn/url?format=mp3&rid={}&response=url&type=convert_url3&br=128kmp3&from=web&t=1616159211200&httpsStatus=1&reqId=f8586c01-88b3-11eb-b442-d7b57b6d2564.format(list_1[i])

   music_data = requests.get(url=url,headers=headers,proxies=proxy).text

   #print(music_data)

   e = {"code": 200, "msg": "success", "url": "(.*?)"}

   music_url = re.findall(e, music_data, re.S)[0]

   #print(music_url)

   download_music(music_url,music_name)

  

  最后下载保存。

  具体函数如下

  

#在当前目录创建文件夹,用于存放下载的音乐

  if not os.path.exists(酷我音乐):

   os.mkdir(酷我音乐)

  #下载音乐并且保存的函数

  def download_music(url,music_name):

   music_name = music_name+".mp3"

   music = requests.get(url=url,proxies=proxy).content

   path = 酷我音乐/ + music_name

   with open(path, wb) as fp:

   fp.write(music)

   listbox_1.insert(END, music_name+ 下载完成!)

  

  同时,我们在用python写爬虫时会被反爬,下列代码为反反爬措施

  

#ip代理池

  ip = [{"HTTP":"175.42.129.105"},{"HTTP":"121.232.148.97"},{"HTTP":"121.232.148.72"}]

  proxy = random.choice(ip)

  proxy = json.loads(proxy)

  #反反爬headers

  headers = {

   User - Agent: Mozilla/5.0(Windows NT 10.0;WOW64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/90.0.4430.85Safari/537.36,

   Referer: http://www.kuwo.cn/search/list?key=%E7%83%AD%E7%88%B1105%C2%B0C%E7%9A%84%E4%BD%A0,

   csrf: 0BXQD7I99LN,

   Cookie: ,

  }

  

  这里的cookie是保持你的登录状态的,相当于验证你的身份,写上你自己的即可。

  这里的csrf与cookie写你自己的就行,源代码中我会空着,注意修改。还有,复制cookie之前先在网站登录,cookie会

  记录你的登录状态,不登录不行哦

  这里的cookie和csrf在第一次请求的header中,如下图

  

  源代码

  代码在这,拿走不谢~~~

  

import requests

  import random

  import json

  import re

  import os

  import tkinter

  from tkinter import *

  list_1 = [] #放置音乐rid的列表

  #ip代理池

  ip = [{"HTTP":"175.42.129.105"},{"HTTP":"121.232.148.97"},{"HTTP":"121.232.148.72"}]

  proxy = random.choice(ip)

  proxy = json.loads(proxy)

  #反反爬headers

  headers = {

   User - Agent: Mozilla/5.0(Windows NT 10.0;WOW64)AppleWebKit/537.36(KHTML,likeGecko)Chrome/90.0.4430.85Safari/537.36,

   Referer: http://www.kuwo.cn/search/list?key=%E7%83%AD%E7%88%B1105%C2%B0C%E7%9A%84%E4%BD%A0,

   csrf: , #填你的

   Cookie: , #填你的

  }

  #在当前目录创建文件夹,用于存放下载的音乐

  if not os.path.exists(酷我音乐):

   os.mkdir(酷我音乐)

  #下载音乐并且保存的函数

  def download_music(url,music_name):

   music_name = music_name+".mp3"

   music = requests.get(url=url,proxies=proxy).content

   path = 酷我音乐/ + music_name

   with open(path, wb) as fp:

   fp.write(music)

   listbox_1.insert(END, music_name+ 下载完成!)

  #解析音乐url的函数

  def get_music_url():

   index = listbox.curselection() #返回选取的索引,是一个元组

   for i in index:

   music_name = listbox.get(i)

   listbox_1.insert(END, music_name + 开始下载)

   url = http://www.kuwo.cn/url?format=mp3&rid={}&response=url&type=convert_url3&br=128kmp3&from=web&t=1616159211200&httpsStatus=1&reqId=f8586c01-88b3-11eb-b442-d7b57b6d2564.format(list_1[i])

   music_data = requests.get(url=url,headers=headers,proxies=proxy).text

   #print(music_data)

   e = {"code": 200, "msg": "success", "url": "(.*?)"}

   music_url = re.findall(e, music_data, re.S)[0]

   #print(music_url)

   download_music(music_url,music_name)

  #获取音乐搜索列表的函数

  def get_music_list():

   name = entry.get()

   listbox.delete(0, END)

   #循环表示加载三页音乐

   for k in range(1,4):

   url = http://www.kuwo.cn/api/www/search/searchMusicBykeyWord?

   data = {

   key: name,

   pn: k,

   rn: 30,

   httpsStatus: 1,

   reqId: 161cbd51-cde1-11eb-bf58-bba623268fbb

   }

   response = requests.get(url=url,headers=headers,params=data,proxies=proxy).text

   dic_data = json.loads(response)

   list_data = dic_data[data][list]

   #listbox.delete(0,END)

   for i in list_data:

   music_name = i[name]+-+i[artist]

   listbox.insert(END, music_name)

   music_id = i[rid]

   list_1.append(music_id)

  # 创建窗口

  window = tkinter.Tk()

  #设置标题

  window.title(音乐下载器,)

  #设置窗口大小及位置

  window.geometry(900x460+500+100)

  #标签组件

  lab = Label(window,text=请输入要下载的歌曲:,font=(华文行楷,15))

  # #标签定位

  lab.grid(row=0,column=0)

  #输入框组件

  entry = Entry(window,font=(隶书,20),width=20)

  entry.grid(row=0,column=1)

  #搜索按钮

  btn = Button(window,text=搜索,font=(隶书,15),width=20,command=get_music_list)

  btn.grid(row=0,column=2)

  #列表框 #可以设置多选,selectmode=MULTIPLE

  listbox = Listbox(window,font=(隶书,16),width=45,heigh=15)

  listbox.grid(row=1,columnspan=2)

  listbox_1 = Listbox(window,font=(隶书,16),width=35,heigh=15)

  listbox_1.grid(row=1,column=2)

  #下载按钮

  btn_1 = Button(window,text=开始下载,font=(隶书,15),command=get_music_url)

  btn_1.grid(row=2,column=0)

  #退出按钮

  btn_2 = Button(window,text=退出程序,font=(隶书,15),command=window.quit)

  btn_2.grid(row=2,column=2)

  # 消息循环显示界面

  window.mainloop()

  

  效果图

  

  看了图,是不是感觉很nice!

  以上就是python网络爬虫实现个性化音乐播放器示例解析的详细内容,更多关于python实现音乐播放器的资料请关注盛行IT软件开发工作室其它相关文章!

郑重声明:本文由网友发布,不代表盛行IT的观点,版权归原作者所有,仅为传播更多信息之目的,如有侵权请联系,我们将第一时间修改或删除,多谢。

留言与评论(共有 条评论)
   
验证码: