学生考勤管理系统设计报告

上传人:平*** 文档编号:17615091 上传时间:2017-11-11 格式:DOC 页数:27 大小:1.27MB
返回 下载 相关 举报
学生考勤管理系统设计报告_第1页
第1页 / 共27页
学生考勤管理系统设计报告_第2页
第2页 / 共27页
学生考勤管理系统设计报告_第3页
第3页 / 共27页
学生考勤管理系统设计报告_第4页
第4页 / 共27页
学生考勤管理系统设计报告_第5页
第5页 / 共27页
点击查看更多>>
资源描述

《学生考勤管理系统设计报告》由会员分享,可在线阅读,更多相关《学生考勤管理系统设计报告(27页珍藏版)》请在金锄头文库上搜索。

1、C/C+程序设计专题实验报告题目:学生考勤管理系统设计 班级:电子信息科学与技术 131姓名: 邬 帅 斌 0目录目录 .1摘要.21.设计要求和目的 .21.1 设计目的.31.2 问题描述.31.3 功能要求.31.4 问题的解决方案.32 设计思路和方法 .43 主模块设计.54.运行测试及结果 .135. 总结 .16参考文献 .16源代码.171摘要随着信息技术在管理上越来越深入的应用,管理信息系统的实施在技术上已经逐步成熟。管理信息系统是一个不断发展的学科,任何单位要生存要发展,要提高效率地把内部活动有机地组织起来,就必须建立与自身特点相适应的信息管理系统。由于学校的学生管理系统缺

2、乏开发,而学生人数不断增加,学生信息的不断更新,所以,学生考勤管理系统的建立就显得非常重要了。本设计是基于 Visual basic C+ 6.0 开发环境,至上而下,层次化地设计学生考勤管理,综合考虑学生考勤管理所涉及的多方面问题,结合学校和教师的情况,有步骤,条理清晰的设计,操作简单,很方便的实现了学校和老师对学生考勤的管理。关键词:学生考勤管理 C+ 信息录入 查询21.设计要求和目的1.1 设计目的(1)进一步锻炼学生对 C+课程基础知识和实践技能的掌握和运用;(2)要求学生基本掌握面向对象程序设计的基本思路和方法;(3)要求学生能够利用所学的基础知识和技能,解决简单的面向对象设计问题

3、。1.2 问题描述学生信息包括:学号、姓名、性别、年龄、班级等信息。考勤信息包括:缺课日期、第几节课、课程名称、学生姓名、缺课类型(迟到、早退、请假和旷课) 。1.3 功能要求(1)添加功能:程序能够添加学生的记录和缺课记录,提供选择界面供用户选择所要添加的类别。添加学生记录时,要求学号要唯一,如果添加了重复学号的记录时,则提示数据添加重复并取消添加。(2)查询功能:可根据学号、姓名等信息对已添加的学生记录进行查询,如果未找到,给出相应的提示信息,如果找到,则显示相应的记录信息。还可以按课程名、学生姓名对缺课记录进行查询。(3)显示功能:可显示当前系统中所有学生的记录和缺课记录,每条记录占据一

4、行。(4)编辑功能:可根据查询结果对相应的记录进行修改,修改时注意学号的唯一性。(5)删除功能:主要实现对已添加的学生记录进行删除。如果当前系统中没有相应的记录,则提示“记录为空!”并返回操作。(6)统计功能:能根据多种参数进行统计。能按课程名统计出学生旷课的信息、还可以按姓名统计出任一学生的旷课情况。需要排序。(7)保存功能:可将当前系统中各类记录存入文件中,存入方式任意。(8)读取功能:可将保存在文件中的信息读入到当前系统中,供用户进行使用。1.4 问题的解决方案 根据系统功能要求,可以将问题解决分为以下步骤:(1)应用系统分析,建立该系统的功能模块框图以及界面的组织和设计;(2)分析系统

5、中的各个实体及它们之间的关系;(3)根据问题描述,设计系统的类层次;(4)完成类层次中各个类的描述;(5)完成类中各个成员函数的定义;3(6)完成系统的应用模块;(7)功能调试;(8)完成系统总结报告。(7)功能调试;(8)完成系统总结报告。2.设计思路和方法2.1 设计思路根据设计要求,经分析可将整个系统划分为 7 个功能模块。数据管理中可以对学生的基本信息、课程的基本信息、学生缺课的查询、添加、删除和修改。查询管理通过根据学生姓名,课程姓名 时间段儿等信息,查询单个学生的缺课记录,单科课的旷课记录,单个学生的旷课记录。功能模块图如下图所示:学生考勤管理程序修改学生缺课记录查看学生旷课记录查

6、看单科旷课记录查询学生缺课记录建立学生缺课记录储存学生旷课记录载入学生旷课记录2.2 数据结构设计struct xuekechar xueke_name50;int people_num;这是定义了一个 xueke 结构体,用来存放一个学科名及其相应的旷课人数;struct student char name50;long time;int lesson_time;char lesson_name50;int chidao_num;4int zaotui_num;int qingjia_num;int kuangke_num;struct student *next;这是定义了一个 stude

7、nt 的结构体,用来存放一个学生的考勤记录,其中有,字符数组 name50,lesson_name50,分别存放学生名字,缺课课程名字;int 型变量 lesson_time,chidao_num,zaotui_num,qingjia_num, kuangke_num,分别来存放,缺课节次,迟到次数,早退次数,请假次数,旷课次数 long型变量 time,记录时间。3.主模块设计3.1 建立学生缺课记录子模块建立的学生人数,学生基本信息(包括缺课时间、学生姓名、课程名称、节次、迟到次数、早退次数、请假次数、旷课次数) ,用 creat()函数,如下图:开始i n t i , b ;s t r

8、u c t s t u d e n t * h e a d , * p 1 , * p 2 ; p r i n t f ( 请输入要建立资料的学生人数 : ) ;s c a n f ( % d , & b ) ;h e a d = p 2 = N U L L ;p 1 = ( s t r u c t s t u d e n t * ) m a l l o c ( L E N ) ;输入第一个学生成绩h e a d = p 1 ;p 2 = p 1 ;i = 0 ;s t u d e n t _ n u m + + ;i n e x t = p 1 ;p 2 = p 1 ;s t u d e n

9、 t _ n u m + + ;i + +p 2 - n e x t = N U L L结束YN53.2 修改学生缺课记录子模块c h a r x i u g a i _ n a m e 5 0 ;c h a r x i u g a i _ x u e k e _ n a m e 5 0 ;i n t k ;开始p r i n t f ( 请输入要修改的学生姓名与学科名称 : ) ; s c a n f ( % s % s , x i u g a i _ n a m e, x i u g a i _ x u e k e _ n a m e ) ;s t r u c t s t u d e n

10、t * p 1 , * p 2 ; p 2 = ( s t r u c t s t u d e n t * ) m a l l o c ( L E N ) ; p 1 = h e a d ;s t r c m p ( x i u g a i _ n a m e , p 1 - n a m e ) ! = 0 & & ( p 1 - n e x t ! = N U L L ) & & s t r c m p ( x i u g a i _ x u e k e _n a m e , p 1 - l e s s o n _ n a m e ) !p 1 = p 1 - n e x t ;s t r

11、c m p ( x i u g a i _ n a m e , p 1 - n a m e ) = = 0 & & s t r c m p ( x i u g a i _ x u e k e _n a m e , p 1 - l e s s o n _ n a m e ) = = 0显示修改菜单选择修改项目并完成修改结束63.3 修改学生缺课记录子模块开始p r i n t f ( 请输入要查询的人名 : ) ; s c a n f ( % s , c h a x u n_ n a m e ) ;i n t i = 0 ;c h a r c h a x u n _ n a m e 5 0 ;s t r u c t s t u d e n t * p ;p = h e a d ;i n a m e ) = = 0输出 p 所指向的结构体数据i + +结束3.4 查看单科旷课记录子模块根据学科名称和时间范围查出所有在该范围内旷课的学生以及次数, 如下图:7开始s t r u c t s t u d e n t * p 1 , * p 2 , * p 3 ; c h a r l e s s o n 5 0

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 办公文档 > 其它办公文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号