本文实例为大家分享了Python实现GUI学生信息管理系统的具体代码,供大家参考,具体内容如下
项目环境:
软件环境:
OS:RedHat6.3
Lib:Pygtk
Language:Python
Support tool:Glade3
项目简述:
①Glade3设计用户的登录窗口,功能主窗口
②通过Gtk.Builder初始化,载入界面
③在Mysql.py文件中实现Python操作数据库。
④在stuManager.py中实现学生信息的查询,删除,修改,终端登录,图形统计等功能
⑤在Glade中定义函数触发信号,实现功能的连接。
项目测试:
①登录窗口
②主窗口
③删除信息
④修改信息
⑤登录终端
⑥学生成绩
⑦图形统计(没做好)
⑧查找信息
部分代码:
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]) ...........
更多学习资料请关注专题《管理系统开发》。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。