[VFP课程设计] 学生成绩管理系统

2019-02-15 10:59

学生成绩管理系统

摘要 本文通过用VFP编写学生成绩管理系统,利用软件工程原理,采用生命周期方法学,

其开发主要包括后台数据库的建立和维护以及前端应用程序的开发两个方面,实现了学生成绩数据库的创建及学生成绩的输入、浏览、维护和统计。

关键字 成绩管理 浏览 打印 维护 统计

1. 引言

每次考试结束,老师们总要统计大量的学生成绩,这些数据的归档、统计工作任务重,时间紧,统计结束后往往错误百出。长时间以后,将产生大量文件和资料,给查找、维护带来不少困难。随着学校信息化水平不断提高,不少学校开始利用计算机处理这些数据;可以用EXCLE统计数据,但是对于一些老师尤其老教师总有些复杂。

学生成绩管理系统是为了更好的管理学生考试成绩而开发的数据库管理软件。根据学校实际要求,即实现学生基本信息、成绩的录入,删除,查询,维护以及成绩的统计分析等几方面功能。管理员可以通过查询,实现删除、修改学生的基本信息;可根据实际需求,自由添加、删除课程;还能打印学生成绩表(总分成绩表和单课成绩表)。学生成绩管理系统可帮助老师们方便快捷地管理这些繁琐地数据。学生成绩管理系统具有手工管理无比优越的优点:查找方便,可靠性高,保密性好,成本低。

基于上述因素,利用软件工程原理,采用生命周期方法学,经过可行性研究,需求分析,总体设计,以及编码、测试和最后运行成功。微软公司地VISUAL FOXPROL具有强大的数据库管理功能,可以方便编写出小型的信息处理系统,能够有效地存储数据,满足用户的应用需求(信息要求和处理要求)。设计指导思想:一切为用户着想,界面美观大方,操作尽量简单明了,而且作为一个实用系统要有良好的容错性,在用户出现误操作时,及时给出警告,以便用户及时更正。下面介绍学生成绩管理系统的制作过程。 2.需求分析

需求分析简单的说就是分析用户的要求,通过调查、收集与分析,获得用户对数据库的如下要求:

2.1信息要求:指用户需要从数据库中获得信息的内容与性质。

本系统需要的输入数据:学生信息(学号,姓名,班级,性别,出生日期)、课程信息(课程名,满分)、考生成绩;输出数据:学生成绩报表、学生信息报表、课程报表、成绩报表。

2.2处理要求:指用户要完成什么处理功能。 本系统功能需求可归纳如下: ① 数据登记

登记功能用于把各种手填的数据及时登记系统定义表中,还能修改这些数据(学生信息、课程信息、成绩)。 ② 数据浏览

能浏览学生信息、课程信息、成绩。 ③ 数据打印

能打印学生信息表、课程信息表、成绩表(单课成绩和总分成绩)。 ④ 数据统计

能统计各班学生总数和男女人数,统计各班学生的总分、排名,及各单课的排名。

2.3 性能要求:维护数据的安全性.

设定密码,限制非法用户的使用;还能修改密码,维护系统的安全性。

1

3.数据库设计

数据库设计的任务是确定系统所需的数据库。数据库是表的集合,通常一个系统只需一个数据库。建立本系统的数据库 数据data\\test.dbc

根据需求分析画出E-R图

成绩 班级 学号 课程号

m n 学生 姓名 课程名 课程 学习 性别 出生日期 名次 满分

3.1逻辑设计:确定数据库所含表及字段

学生信息表:xs(学号,姓名,班级,性别,出生日期) 课程信息表:kc(课程号,课程名,满分)

考生成绩表:cj(学号,姓名,班级,课程名,成绩,名次)

括号外字符号是表名,括号内是字段名,有下划线的字段为关联关键字 3.2物理设计

学生信息表:(data\\xs.dbf) xs(xh c(7),xm c(8),bj c(10),xb c(2),csrq d)

课程信息表:(data\\kc.dbf) kc(kch c(5),kcm c(20),mf n )

考生成绩表:(data\\cj.dbf) cj(xh c(7),xm c(8),bj c(10),kcm c(20),

cj n(5,1) ,mc n)

自由表: (data\\pass.dbf) pass(pass c(10))

4.总体设计

按功能分类是总体设计的常用方法,用层次图(Hierarchy Chart 简称HC图)表示,自上而下分层

主程序 系统功能 数据维护模块 数据浏览模块 成绩管理模块

修改密码 退出 修改 搜索 删除 浏览 打印 输入 统计 分析

4.1数据维护模块

包括对学生信息表、课程信息表、考生成绩表的插入、修改、删除、搜索等。 4.2数据浏览模块

包括对学生信息表、课程信息表、考生成绩表的选择浏览、打印。 4.3成绩管理模块

包括对学生成绩的输入,总分和单课的统计和排名,分析各分数段人数的分布情况。 5.初始用户界面设计

系统层对应菜单文件,子系统层对应菜单标题,功能层对应子菜单项

2

系统功能 维护 浏览 成绩管理 版本信息 修改密码 学生信息表 学生信息表 成绩输入 课程信息表 课程信息表 成绩统计 退出 考生成绩表 考生成绩表 成绩分析 6.模块设计与编码 6.1主文件(data\\main.prg) 设计系统环境,调用登录表单 代码如下: SET TALK off

set sysmenu off *关闭系统菜单

set cent on *年份的世纪部分用4位输出 _screen.windowstate=2

_screen.icon=\系统图标 _screen.maxbutton=0 _screen.minbutton=1 _screen.closable=.f.

_screen.picture=\系统背景画

MODIFY WINDOW SCREEN TITLE \学生成绩管理系统 今天是:\ZOOM WINDOW SCREEN MAX

open database data\\数据test.dbc do form forms\\pass

read even *建立事件循环 quit

6.2菜单程序(mpr\\menu.mpr)的建立

往命令窗口键入命令modi menu menu 出现菜单设计窗口

①“退出”菜单项 命令 clear events *停止事件循环,

转去执行read event后的命令

②调用各表单命令 如调用修改密码表单(forms\\xiu.scx) do form forms\\xiu.scx

③插入分隔符 菜单名称 \\- 结果 菜单项# ④设计快捷键

对于菜单项 在菜单命令后加(\\<字母)如系统功能(\\提示选项对话框,在键标签中键入CTRL+字母(J除外)。 6.3 数据库中的数据需要以表单的形式显示,本系统需建立以下表单:

a. 系统登陆表单 b.密码修改表单 c.维护学生信息表单 d.维护课程信息表单 e.维护考生成绩表单 f.浏览学生信息表单 g.浏览课程信息表单 h.浏览成绩表单 i.成绩输入表单 j.总分成绩统计表单 k.单课成绩统计表单 l.成绩统计表单

设计表单步骤:

①在项目管理器中,文档->表单->新建。

②设计表单属性 重要属性有 Caption AutoCenter Height Width WindowType Icon ③添加各标签、文本框,设定文本框与源表中源字段的绑定 有代码的写代码 如属性InteractiveChange Event 当用鼠标或键盘修改控件的值时发生的事件

3

④创建命令按钮

详细介绍:

a.系统登陆表单 forms\\pass.scx

功能:用户名和密码三次输入错误,自动退出系统;

限制了非法用户的使用,维护了系统数据的安全。

构成:三个标签(工作人员登录,用户名,密码)两个文本框

两个命令按钮(取消 登录)

命令按钮 登录

use data\\pass go top

if thisform.user.value=\do menu\\menu.mpr*若用户名和密码正确,则进入本系统。 thisform.release else

#define missmatch_loc \用户或口令错,请重新登录!\wait window missmatch_loc timeout 1 *系统延时 thisform.user.value='' thisform.pass.value='' thisform.user.setfocus numcount=numcount+1

if numcount=4 *表单初始化事件有:public numcount numcount=0 mess =messagebox(\三次口令错,将退出程序!\退出\ clear event

release thisform endif endif

b.密码修改表单

功能:可以随时修改密码,维护系统安全。

构成:四个标签(请输入,旧密码,新密码,确认新密码)三个文本框

两个命令按钮(修改,退出)

c.维护成绩表单 forms\\cj.scx

功能:能查询到某位学生成绩,可以对它修改,删除,

还可以清空整个cj.dbf的数据。 属性设计如图1

4

命令按钮 删除

use data\\cj excl *以独占的方式打开cj.dbf

locate for xh=this.parent.text1.value .and.kcm=this.parent.text4.value delete

mess=messagebox('彻底删除吗?',4+16+0,'删除') *弹出信息对话框 if mess=6

pack *如果确定,则彻底删除 else

recall *否则恢复 endif

thisform.refresh 下一个 skip 1

if eof() *如果到了末记录

=messagebox(\已是末记录!\信息窗口\ skip -1

this.enabled=.f. else

this.enabled=.t. endif

if !bof()

this.parent.command3.enabled=.t. else

this.parent.command3.enabled=.f. endif

thisform.refresh d.维护学生信息表单

功能:根据学号能快捷查询到某个学生,对其进行修改,删除操作,

还能添加学生记录。

构成:六个标签(学号,姓名,班级,出生日期,性别)四个文本框

一个选项按钮(性别) 命令按钮同图1

e.维护课程信息表单

功能:根据课程号能快捷查询到某门课程,对其进行修改,删除操作,

还能添加课程记录。

构成:四个标签(课程号,课程名,满分,课程表)

四个文本框 命令按钮同图1

f.浏览学生信息表单

功能:统计出全体学生人数,男女人数和各班级人数和男女人数;

打印出各班级学生信息

构成:一个页框(全体学生,各班学生)一个退出按钮 每页一个表格

全体学生页:三个标签(学生总数,男生总数,女生总数)

三个文本框 打印按钮

5


[VFP课程设计] 学生成绩管理系统.doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:金融工程_第二版_郑振龙__课后习题和答案整理(华北电力大学)

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: