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

作者:唐美好 时间:2022-03-19 19:35:36 

本文实例为大家分享了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])
...........

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

来源:http://iotos.iteye.com/blog/2093002

标签:Python,GUI,管理系统
0
投稿

猜你喜欢

  • Python后台开发Django会话控制的实现

    2022-11-09 22:29:16
  • Python实现文本特征提取的方法详解

    2023-05-09 05:09:19
  • 关于python中密码加盐的学习体会小结

    2022-05-13 09:47:04
  • Python flask框架端口失效解决方案

    2021-02-19 23:48:46
  • Flask-Sqlalchemy的基本使用详解

    2023-06-16 19:40:02
  • python实现Pyecharts实现动态地图(Map、Geo)

    2021-01-21 11:33:58
  • Python中Pyspider爬虫框架的基本使用详解

    2021-04-01 06:00:31
  • Python列表创建与销毁及缓存池机制

    2023-11-29 14:21:21
  • python中偏函数partial用法实例分析

    2021-03-24 21:35:23
  • 使用jupyter notebook运行python和R的步骤

    2023-03-30 18:22:50
  • python中elasticsearch_dsl模块的使用方法

    2022-03-23 07:57:31
  • 使用html+js+css 实现页面轮播图效果(实例讲解)

    2024-02-24 01:48:44
  • 理解 XMLDOM 的节选

    2008-02-17 14:48:00
  • 如何利用python的tkinter实现一个简单的计算器

    2021-09-12 09:19:52
  • Python Django路径配置实现过程解析

    2023-11-13 20:50:02
  • 使用symfony命令创建项目的方法

    2023-11-15 10:07:45
  • MYSQL教程:服务器优化和硬件优化

    2009-02-27 15:43:00
  • perl特殊符号及默认的内部变量

    2023-08-08 02:13:20
  • Vue.js监听select2的值改变进行查询方式

    2024-04-30 10:42:13
  • python为QT程序添加图标的方法详解

    2021-05-16 15:56:08
  • asp之家 网络编程 m.aspxhome.com