本文实例为大家分享了Python实现GUI学生信息管理系统的具体代码,供大家参考,具体内容如下
项目环境:
软件环境:
OS:RedHat6.3
Lib:Pygtk
Language:Python
Support tool:Glade3
项目简述:
①Glade3设计用户的登录窗口,功能主窗口
②通过Gtk.Builder初始化,载入界面
③在Mysql.py文件中实现Python操作数据库。
④在stuManager.py中实现学生信息的查询,删除,修改,终端登录,图形统计等功能
⑤在Glade中定义函数触发信号,实现功能的连接。
项目测试:
①登录窗口
②主窗口
③删除信息
④修改信息
⑤登录终端
⑥学生成绩
⑦图形统计(没做好)
⑧查找信息
部分代码:
Terminal.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
#-*- 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
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
|
#!/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 ])
...........
|
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。
原文链接:http://iotos.iteye.com/blog/2093002