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

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

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

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

(0)

相关推荐

  • Python学生成绩管理系统简洁版

    讲起学生成绩管理系统,从大一C语言的课程设计开始,到大二的C++课程设计都是这个题,最近在学树莓派,好像树莓派常用Python编程,于是学了一波Python,看了一点基本的语法想写点东西练下手. 开发环境:Ubuntu+Python2.7 代码如下: #coding=utf-8 #保存学生信息 studentList=[] def addInfo(name,addr): tempInfo={} tempInfo['name']=name tempInfo['addr']=addr student

  • python图书管理系统

    本文实例为大家分享了python图书管理系统的具体代码,供大家参考,具体内容如下 实现语言:python 图形框架:DTK+2.0 数据库框架:SQLite 3.0 本程序需要以下部件运行: Python2.5.0.GTK+2.16.Pygtk 2.16.PyGobject 2.14.Pycairo 1.4 LibiaryManager.py #!/usr/bin/python # -*- coding: utf-8 -*- import pygtk pygtk.require('2.0') i

  • python面向对象实现名片管理系统文件版

    本文实例为大家分享了python实现名片管理系统源代码,供大家参考,具体内容如下 import os def print_menu(): print("*"*50) print(" 名片管理系统") print(" 1.添加一个新名片") print(" 2.删除一个名片信息") print(" 3.修改一个名片信息") print(" 4.查找一个名片信息") print("

  • python实现外卖信息管理系统

    本文为大家分享了python实现外卖信息管理系统的具体代码,供大家参考,具体内容如下 一.需求分析 需求分析包含如下: 1.问题描述 以外卖信息系统管理员身份登陆该系统,实现对店铺信息.派送员信息.客服人员信息.订单信息.配送信息等进行有条件查询以及信息的录入.修改.删除等功能. 2.系统功能描述 (1)信息录入:使用wxpython设计排版编写窗口界面,给出录入信息的接口,通过python语句实现与数据库的连接,从而向数据库中插入相应数据. (2)信息修改:使用wxpython设计排版编写窗口

  • python实现学生信息管理系统

    继上篇博客Python实现简易通讯录后,我就想写一个复杂点的学生信息管理系统,这次实现的功能有 1.学生信息的录入管理: 2.学生选课操作: 3.学生选课情况查询: 这次仍然用到sqlite3模块.虽然看着挺简单,但是也踩了不少坑,毕竟刚开始实战,有些细节的还需要多多磨炼啊! 好了,废话不多说,直接上代码,欢迎感兴趣的朋友私信讨论~~~ #-*- coding:utf-8 -*- import sqlite3 #打开本地数据库用于存储用户信息 conn = sqlite3.connect('st

  • python实现图书管理系统

    本文实例为大家分享了python实现图书管理系统的具体代码,供大家参考,具体内容如下 import mysql.connector import sys, os import time import datetime from tkinter import * from tkinter.messagebox import * class Libop: user = 'root' pwd = '' host = 'localhost' db = 'library' data_file = 'mys

  • python3.6+django2.0开发一套学员管理系统

    1.在pycharm中新建project demo1 添加app01 点击create按钮完成新建 2.在demo项目目录下新建目录static,并在settings.py中追加代码: STATICFILES_DIRS=(os.path.join(BASE_DIR, 'static'),) 3.在setting.py中添加模板路径: TEMPLATES = [ { 'BACKEND': '...', 'DIRS': [os.path.join(BASE_DIR, 'templates'),],

  • python实现员工管理系统

    这是一个简易的员工管理系统,实现最简单的功能: 1.登录用户密码验证(错误三次自动退出) 2.支持文本员工的搜索.添加.删除.修改 3.一级层级多个选项.二级层级多个选项,都支持判空.退出.返回上一层级 4.针对删除和修改有员工当前自动搜索到的结果进行参照修改和特殊提醒是否删除 用到的基础知识点比较多: 1.计数器 2.while True 以及给while做退出层级标记 3.if-elif-else 的嵌套使用 4.continue 和 break 以及简单函数定义def 5.键盘抓取 raw

  • python学生信息管理系统

    本文实例为大家分享了python学生信息管理系统的具体代码,供大家参考,具体内容如下 #编译环境为python3 #学生信息管理系统包括基本的信息功能,能够实现学生信息的输入,查询,增添和删除 #基本框架:开始操作菜单,接收输入选项,调用相应的函数实现对应的功能,循环回到开始菜单, #操作菜单: student = [] def studentMeau(): print('-'*30) print('-------学生信息管理系统-------') print(' 1.添加学生信息') prin

  • Python实现学生成绩管理系统

    本文实例为大家分享了Python实现学生成绩管理系统的具体代码,供大家参考,具体内容如下 基本功能: 输入并存储学生的信息:通过输入学生的学号.姓名.和分数,然后就可以把数据保存在建立的student文件里面. 打印学生的所有信息:通过一个打印函数就可以把所有的信息打印在屏幕上. 修改学生信息:这个功能首先通过查询功能查询出该学生是否存在,如果存在就对该学生的信息进行修改,如果不存在则返回到主界面. 删除学生信息:该功能是对相应的学生进行删除操作,如果学生存在就查找到进行删除. 按学生成绩进行排

随机推荐