Python实现GUI学生信息管理系统


Posted in Python onApril 05, 2020

本文实例为大家分享了Python实现GUI学生信息管理系统的具体代码,供大家参考,具体内容如下

项目环境: 

软件环境: 

                  OS:RedHat6.3
                  Lib:Pygtk
                  Language:Python
                  Support tool:Glade3

项目简述:

①Glade3设计用户的登录窗口,功能主窗口
②通过Gtk.Builder初始化,载入界面
③在Mysql.py文件中实现Python操作数据库。
④在stuManager.py中实现学生信息的查询,删除,修改,终端登录,图形统计等功能
⑤在Glade中定义函数触发信号,实现功能的连接。

项目测试:

①登录窗口

Python实现GUI学生信息管理系统

②主窗口

Python实现GUI学生信息管理系统

③删除信息

Python实现GUI学生信息管理系统

④修改信息

Python实现GUI学生信息管理系统

⑤登录终端

Python实现GUI学生信息管理系统

⑥学生成绩

Python实现GUI学生信息管理系统

⑦图形统计(没做好)

⑧查找信息

Python实现GUI学生信息管理系统

部分代码:

Terminal.py

#-*- coding=utf-8 -*- 
#!/usr/bin/python 
##################################################################### 
## Filename: terminal.py 
##  
## Copyright (C) 2014.6 
## Author: TangMeiHao@760209035@qq.com 
##  
## Description: python + pygtk(gtk)实现学生信息管理系统 
##  
###################################################################### 
 
import vte 
import gtk 
 
 
class MyTerm(): 
 def __init__(self): 
 """初始化一个term对象""" 
 self.terminal=vte.Terminal() 
 self.terminal.connect("child-exited",lambda term: self.vte_exit()) 
 self.terminal.fork_command() 
 self.terminal.set_size(10,20) 
 
 def vte_exit(self): 
 """当terminal退出时,直接重新产生一个terminal,并clear初始化""" 
 self.terminal.fork_command() 
 self.terminal.feed_child("clear\n") 
 
 def vte_message(self): 
 pass

Stu_Sys.py

#!/usr/bin/python 
#-*- coding:utf-8 -*- 
###################################################################### 
## Filename: Stu_Sys.py 
##  
## Copyright (C) 2014.6 
## Author: TangMeiHao@760209035@qq.com 
##  
## Description: python + pygtk(gtk)实现学生信息管理系统 
##  
###################################################################### 
 
import gtk 
import gtk.glade 
from terminal import * 
import MySQLdb 
 
#系统类 
class system: 
 #定义数据库的变量 
 host='localhost' 
 user='root' 
 passwd='aixocm' 
 db='student' 
 port=3306 
 charset='utf8' 
 
 def __init__(self): 
 # 定义所使用的glade文件 
 self.glade_file = "Student.glade" 
 self.glade = gtk.Builder() 
 self.glade.add_from_file(self.glade_file) 
 self.glade.connect_signals(self) 
 self.glade.get_object("window1").set_size_request(800,500) 
 self.glade.get_object("window1").set_position(gtk.WIN_POS_CENTER) 
 
 #从xml文件中读取数据,并链接必要的信号 
 for widget in self.glade.get_objects(): 
 if issubclass(type(widget),gtk.Buildable):name=gtk.Buildable.get_name(widget) 
 setattr(self,name,widget) 
 
 #创建一个Terminal的实例,并且添加到登录管理的标签页中 
 self.myterm=MyTerm() 
 self.glade.get_object("vbox2").add(self.myterm.terminal) 
 
 #登录窗口 
 self.dialog3.run() 
 self.dialog3.set_size_request(300,260) 
 self.dialog3.set_position(gtk.WIN_POS_CENTER) 
 
 #登录窗口登录,验证管理员用户,密码. 
 def on_login_click(self,widget,data=None): 
 try: 
 conn=MySQLdb.connect(host=system.host,user=system.user,passwd=system.passwd, 
 db=system.db,port=system.port,charset=system.charset) 
 cur=conn.cursor() 
 manager_name=cur.execute('select manager_name from manager') 
 name=cur.fetchmany(1) 
 manager_passwd=cur.execute('select manager_passwd from manager') 
 
  
 text16=self.entry16.get_text() 
 text17=self.entry17.get_text() 
 
 if text16!=name: 
 #验证成功,关闭登录窗口 
 self.dialog3.destroy() 
 #显示窗口 
 self.glade.get_object("window1").show_all() 
 
 else: 
 #提示框 
 login_waring='亲爱的管理员,你登录的用户或密码误' 
 self.dialog1buffer=self.textview3.get_buffer() 
 self.dialog1buffer.set_text(str(login_waring)) 
 self.dialog1.set_size_request(300,260) 
 self.dialog1.set_position(gtk.WIN_POS_CENTER) 
 self.dialog1.run() 
 
 except MySQLdb.Error,e: 
 print "Mysql Error %d: %s" % (e.args[0], e.args[1]) 
...........

更多学习资料请关注专题《管理系统开发》。

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

Python 相关文章推荐
python网络编程学习笔记(四):域名系统
Jun 09 Python
深入理解Python中命名空间的查找规则LEGB
Aug 06 Python
浅谈Python基础之I/O模型
May 11 Python
python实现数据写入excel表格
Mar 25 Python
完美解决Pycharm无法导入包的问题 Unresolved reference
May 18 Python
解决Python中list里的中文输出到html模板里的问题
Dec 17 Python
基于Python实现迪杰斯特拉和弗洛伊德算法
May 27 Python
Python3实现的反转单链表算法示例
Mar 08 Python
Python-copy()与deepcopy()区别详解
Jul 12 Python
Python安装selenium包详细过程
Jul 23 Python
Python3操作YAML文件格式方法解析
Apr 10 Python
Alpine安装Python3依赖出现的问题及解决方法
Dec 25 Python
使用python 爬虫抓站的一些技巧总结
Jan 10 #Python
python版学生管理系统
Jan 10 #Python
python实现用户管理系统
Jan 10 #Python
python的Tqdm模块的使用
Jan 10 #Python
python3.6 实现AES加密的示例(pyCryptodome)
Jan 10 #Python
Python设计模式之MVC模式简单示例
Jan 10 #Python
Python设计模式之命令模式简单示例
Jan 10 #Python
You might like
PHP5 操作MySQL数据库基础代码
2009/09/29 PHP
基于initPHP的框架介绍
2013/04/18 PHP
Yii2 rbac权限控制之rule教程详解
2016/06/23 PHP
10个值得深思的PHP面试题
2016/11/14 PHP
如何在Laravel5.8中正确地应用Repository设计模式
2019/11/26 PHP
javascript实现 在光标处插入指定内容
2007/05/25 Javascript
使用JQuery和s3captche实现一个水果名字的验证
2009/08/14 Javascript
用nodejs访问ActiveX对象,以操作Access数据库为例。
2011/12/15 NodeJs
javascript获取作用在元素上面的样式属性代码
2012/09/20 Javascript
将两个div左右并列显示并实现点击标题切换内容
2013/10/22 Javascript
jQuery处理xml格式的返回数据(实例解析)
2013/11/28 Javascript
javascript中的this详解
2014/12/08 Javascript
JavaScript中的console.profile()函数详细介绍
2014/12/29 Javascript
JQ实现新浪游戏首页幻灯片
2015/07/29 Javascript
实例详解JSON数据格式及json格式数据域字符串相互转换
2016/01/07 Javascript
Angular.JS学习之依赖注入$injector详析
2016/10/20 Javascript
在vue中解决提示警告 for循环报错的方法
2018/09/28 Javascript
vue的keep-alive用法技巧
2019/08/15 Javascript
基于vue和websocket的多人在线聊天室
2020/02/01 Javascript
[01:05]主宰至宝剑心之遗
2017/03/16 DOTA
[01:23:45]DOTA2-DPC中国联赛 正赛 CDEC vs Dragon BO3 第一场 1月22日
2021/03/11 DOTA
python 把列表转化为字符串的方法
2018/10/23 Python
Python绘制并保存指定大小图像的方法
2019/01/10 Python
详解Python3网络爬虫(二):利用urllib.urlopen向有道翻译发送数据获得翻译结果
2019/05/07 Python
利用Tensorboard绘制网络识别准确率和loss曲线实例
2020/02/15 Python
在matplotlib中改变figure的布局和大小实例
2020/04/23 Python
tensorflow从ckpt和从.pb文件读取变量的值方式
2020/05/26 Python
html5使用canvas绘制文字特效
2014/12/15 HTML / CSS
加拿大最大的相机店:Henry’s
2017/05/17 全球购物
工商管理实习自我鉴定
2013/09/28 职场文书
高中毕业自我鉴定
2013/12/13 职场文书
基层党建工作宣传标语
2014/06/24 职场文书
依法行政工作汇报材料
2014/10/28 职场文书
卫生院艾滋病宣传活动总结
2015/05/09 职场文书
贫困证明书范文
2015/06/16 职场文书
如何制定销售人员薪酬制度?
2019/07/09 职场文书