python使用Tkinter实现在线音乐播放器


Posted in Python onJanuary 30, 2018

本文实例使用Tkinter实现在线音乐播放器的具体代码,供大家参考,具体内容如下

1.先使用Tkinter库写界面
2.写点击按钮触发的事件

(1).使用网易音乐的api,返回数据包装成json格式数据,解析数据
(2)涉及到多线程的问题未解决,一个软件默认打开一个线程,当播放歌曲时,显示界面就会卡掉,导致python停止工作

代码:

#coding=utf-8 
 
from Tkinter import * 
import tkMessageBox 
import urllib 
import json 
import mp3play 
import time 
 
musicList = [] 
 
#定义点击按钮响应的函数 
def music(): 
 #print "按钮点击" 
 #先判断用户是否在编辑框输入了内容 
 if E.get() == '': 
 #发出警告,需要先import tkMessageBox 
 tkMessageBox.showinfo("提示:","请先输入内容!") 
 #使用return,当满足前面的条件时,不在往下执行 
 return 
 #使用网易api,发送请求,需要import urllib 
 #报错,需要将汉字编码程ascii,才能添加到链接中 
 name = E.get().encode('utf-8') 
 name = urllib.quote(name) 
 html = urllib.urlopen('http://s.music.163.com/search/get/?type=1&s=%s&limit=9'%name).read() 
 #返回json格式数据,可用正则匹配需要数据,也可使用json.loads() 
 print html 
 #将返回文件转化为json格式,提取所需要的数据,需要import json 
 a = json.loads(html) 
 #print a 
 print a[u'result'][u'songs'][0][u'album'][u'name'] 
 #将所有结果显示在列表中 
 #print len(a[u'result'][u'songs'][0]) 
 for i in range(len(a[u'result'][u'songs'][0])): 
 #注意insert参数 
 LB.insert(i,a[u'result'][u'songs'][i][u'album'][u'name']+"("+a[u'result'][u'songs'][i][u'artists'][0][u'name']+")") 
 #先获取到歌曲url列表 
 musicList.append(a[u'result'][u'songs'][i][u'audio']) 
#定义双击列表响应函数 
 
def play(event): 
 #获取点击后返回的结果curselection() 
 #print LB.curselection()[0] 
 urlnum = LB.curselection()[0] 
 #不用流媒体播放,先下载下来再播放 
 # urllib.urlretrieve(musicList[urlnum],'1.mp3') 
 # #播放歌曲,调用import mp3play 
 # time.sleep(50) 
 clip = mp3play.load('1.mp3') 
 clip.play() 
 #设置播放时间import time 
 time.sleep(min(300, clip.seconds())) 
 #死机了,无法响应,因为线程的问题!!!!!! 
 #一个线程同一时间只能做一件事情,放歌时需再开一个线程 
 
#创建父窗口对象, 
top = Tk() 
#可以设置窗口的属性,如:标题,大小 
top.title("在线音乐播放器——张强") 
top.geometry('500x300+800+300') 
#创建编辑框,放到父窗口top上,用pack显示 
E = Entry(top) 
E.pack() 
#创建按钮,定义按钮触发的函数command 
B = Button(top,text="搜 索",command = music) 
B.pack() 
#定义列表的响应函数 
LB = Listbox(top,width = '50',listvariable = StringVar()) 
#绑定触发事件的方式-双击左键,和响应函数 
LB.bind('<Double-Button-1>',play) 
LB.pack()#要放到最后 
#定义标签 
label = Label(top,text = "欢迎使用!",fg = 'red') 
label.pack() 
#循环向windows发送消息,用于显示窗口 
top.mainloop()

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python去除所有html标签的方法
May 05 Python
基于python yield机制的异步操作同步化编程模型
Mar 18 Python
深入解析Python中的__builtins__内建对象
Jun 21 Python
Python实现基于二叉树存储结构的堆排序算法示例
Dec 08 Python
Python3实现带附件的定时发送邮件功能
Dec 22 Python
如何使用VSCode愉快的写Python于调试配置步骤
Apr 06 Python
Python多线程编程之多线程加锁操作示例
Sep 06 Python
python 通过可变参数计算n个数的乘积方法
Jun 13 Python
解决python调用自己文件函数/执行函数找不到包问题
Jun 01 Python
python thrift 实现 单端口多服务的过程
Jun 08 Python
python通过cython加密代码
Dec 11 Python
Jupyter Notebook添加代码自动补全功能的实现
Jan 07 Python
Python字典及字典基本操作方法详解
Jan 30 #Python
Python操作MySQL数据库的三种方法总结
Jan 30 #Python
python3.5 tkinter实现页面跳转
Jan 30 #Python
python 连接各类主流数据库的实例代码
Jan 30 #Python
python操作oracle的完整教程分享
Jan 30 #Python
Python使用wxPython实现计算器
Jan 30 #Python
python链接oracle数据库以及数据库的增删改查实例
Jan 30 #Python
You might like
php下使用以下代码连接并测试
2008/04/09 PHP
js静态作用域的功能。
2006/12/25 Javascript
JavaScript 打地鼠游戏代码说明
2010/10/12 Javascript
AJAX 网页保留浏览器前进后退等功能
2011/02/12 Javascript
js中获取事件对象的方法小结
2011/03/13 Javascript
Prototype源码浅析 Enumerable部分(二)
2012/01/18 Javascript
js 控制下拉菜单刷新的方法
2013/03/03 Javascript
jQuery遍历Table应用示例
2014/04/09 Javascript
关闭页面window.location事件未执行的原因及解决方法
2014/09/01 Javascript
基于jQuery实现简单人工智能聊天室
2017/02/10 Javascript
详解用webpack的CommonsChunkPlugin提取公共代码的3种方式
2017/11/09 Javascript
jQuery实现checkbox全选功能完整实例
2018/07/12 jQuery
Vue中的Props(不可变状态)
2018/09/29 Javascript
微信小程序用户位置权限的获取方法(拒绝后提醒)
2018/11/15 Javascript
前端Electron新手入门教程详解
2019/06/21 Javascript
vue如何实现自定义底部菜单栏
2019/07/01 Javascript
VUE使用axios调用后台API接口的方法
2020/08/03 Javascript
以Flask为例讲解Python的框架的使用方法
2015/04/29 Python
python爬取NUS-WIDE数据库图片
2016/10/05 Python
Python+Selenium+PIL+Tesseract自动识别验证码进行一键登录
2017/09/20 Python
分享给Python新手们的几道简单练习题
2017/09/21 Python
Python实现备份MySQL数据库的方法示例
2018/01/11 Python
windows下 兼容Python2和Python3的解决方法
2018/12/05 Python
对Python正则匹配IP、Url、Mail的方法详解
2018/12/25 Python
如何利用pycharm进行代码更新比较
2020/11/04 Python
使用CSS3实现圆角,阴影,透明
2014/12/23 HTML / CSS
荷兰之家英文站:Holland at Home
2016/10/26 全球购物
Capitol Lighting的1800lighting.com:住宅和商业照明
2019/04/10 全球购物
CSS代码检查工具stylelint的使用方法详解
2021/03/27 HTML / CSS
新农村建设汇报材料
2014/08/15 职场文书
借条如何写
2015/05/26 职场文书
排球赛新闻稿
2015/07/17 职场文书
护士爱岗敬业心得体会
2016/01/25 职场文书
教你怎么用Python生成九宫格照片
2021/05/20 Python
windows server 2012安装FTP并配置被动模式指定开放端口
2022/06/10 Servers
oracle设置密码复杂度及设置超时退出的功能
2022/06/28 Oracle