python学生成绩管理系统gui_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
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python 学生成绩管理系统 GUI 和 MySQL 的结合通常用于创建一个用户友好的界面,以便管理员或教师可以轻松地输入、查看和管理学生的成绩数据。以下是这个系统的一般概述: 1. **GUI (图形用户界面)**: 使用 PythonGUI 库如 Tkinter、PyQt 或 wxPython,你可以设计一个界面,包括输入框用于输入学生姓名、课程名和分数,表格或列表视图显示已有的成绩,以及按钮执行添加、编辑和删除操作。这样,用户可以通过点击和输入来与系统交互。 2. **数据库集成(MySQL)**: MySQL 是一个开源的关系型数据库管理系统,非常适合存储结构化的学生成绩数据。在 Python 中,可以使用 `mysql-connector-python` 或 `pymysql` 这样的库连接 MySQL 数据库。你需要设置一个数据库表来存储字段如学生ID、姓名、课程名和对应的分数。 一个简单的 Python 学生成绩管理系统可能包含以下几个部分: - **数据模型**:定义 Python 类(例如 `Student`, `Course`, 和 `Grade`),对应数据库表。 - **数据库连接**:使用 ORM(如 SQLAlchemy)操作数据库,执行增删改查操作。 - **界面元素**:利用 GUI 库创建输入框、按钮、表格等控件。 - **事件处理**:绑定用户操作到相应的数据库操作,如点击“添加”按钮后保存新记录。 **相关问题--:** 1. 如何在 Python 中使用 Tkinter 创建一个基本的 GUI 界面来输入学生成绩? 2. 如何使用 SQLAlchemy 建立 Python 与 MySQL 数据库的连接? 3. 在实际项目中,如何处理并发和安全性问题,以保护学生成绩数据?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值