教务信息管理系统课程报告

上传人:hao****021 文档编号:166981519 上传时间:2022-11-02 格式:DOCX 页数:19 大小:168.42KB
返回 下载 相关 举报
教务信息管理系统课程报告_第1页
第1页 / 共19页
教务信息管理系统课程报告_第2页
第2页 / 共19页
教务信息管理系统课程报告_第3页
第3页 / 共19页
点击查看更多>>
资源描述
高级语言程序设计课程设计教务信息管理系统题 目:班 级: 软件R7班学生学号:201231001015学生姓名: 麦建波指导老师: 姚金涛 提交时间:2013年5月6日华南农业大学 软件学院教务信息管理系统 1. 系统分析 1.1 问题描述本程序为教务信息管理系统,通过输入学生的相关信息,对数据进行处理和统计,并按需要输入统计处理后的数据到文件中。 1.2 系统功能(1)录入如下信息:学生基本信息:如学号、姓名、性别、年龄、宿舍号码、电话号码等;课程基本信息:课程编号、课程名称、考试成绩、平时成绩、综合成绩、 学分、重修否等。如果重修,需要考虑重修学期、重修成绩,并且要考虑多次重修的情况。(2)录入选课信息(3)录入学生成绩(4)按班统计学生选课情况及考试成绩(5)按课程统计学生名单及考试成绩(6)统计并输出每个同学已修学分及不及格课程 1.3 功能需求描述:(1)加载学生信息及其课程成绩:从文件录入学生的基本资料和课程情况,并覆盖原有数据。(2)新增学生信息及其课程成绩:按要求录入学生的基本资料和课程情况,通过提示信息逐步操作。(3)按班统计学生选课情况及考试成绩:根据录入的数据,以班为单位逐个输出选课情况及对应的成绩。(4)按课程统计学生名单及考试成绩:按提示输入课程编号,查询对应课程的学生名单及其成绩。(5)统计并输出每个同学已修学分及不及格课程:根据录入的数据进行统计,输出全部学生的已修学分及不及格课程的名称。(6)保存学生信息及其课程成绩并退出:将当前的学生基本资料和课程情况保存到文件,并覆盖原有文件。1.4 开发平台及工具介绍(1)硬件环境:u 处 理 器:Intel Pentium 166或更高u 内 存:32MB以上u 硬盘空间:2G以上u 显 卡:SVGA显示适配器(2)软件环境:u 操作系统:Windows98/Me/2000/XP/2007/Vista/7/8等 2. 系统设计 2.1 系统总体结构设计教务信息管理系统保存学生信息及其课程成绩并退出统计学生已修学分及不及格课程按课程统计学生名单及考试成绩按班统计学生选课情况及考试成绩新增学生信息及其课程成绩加载学生信息及其课程成绩 2.2 系统各个功能模块设计(1)加载成功显示相关信息,并提示加载学生总数系统自动从根文件夹读取文件”stu.txt”,依照程序步骤将学生信息输入到程序加载学生信息及其课程成绩(2)学生学号输入“0”返回到主界面在已有加载数据基础上新增学生,依照提示信息依次将学生信息输入到程序新增学生信息及其课程成绩(3)输出完毕后自动返回到主界面继续工作基于当前数据,按班级R1R10分类统计并输出学生所有信息到屏幕和文件”case3.txt”按班统计学生选课情况及考试成绩(4)输入课程编号,查找出已修该课程所有学生并输出其成绩及重修与否到屏幕和文件”case4.txt”课程编号输入“0”返回到主界面按课程统计学生名单及考试成绩(5)基于当前数据,将每位学生已修课程的学分总和及不及格课程输出到屏幕和文件”case5.txt”输出完毕后自动返回到主界面继续工作统计学生已修学分及不及格课程(6)保存成功显示相关信息,并提示保存学生总数,最后退出程序将当前数据以与加载相同的格式输出到文件”stu.txt”,并覆盖原本存在的该文件保存学生信息及其课程成绩并退出 2.3 数据结构的设计学生信息数据结构typedef struct student int age,sub,cla; /年龄,选课数量,班级 double poi; /已修学分 char stun15,name30,sex5,dorn10,phon20; /学号,姓名,性别,宿舍号码,短号电话号码 course les10; /课程信息 struct student*next;student;课程信息数据结构typedef struct course char lessonn15,lessonname50,re5; /课程编号,课程名称,是否重修 double textmark,formalmark,mark,point; /考试成绩,平时成绩,综合成绩,学分 restudy res5; /重修情况 int restime; /重修次数course;重修情况数据结构typedef struct restudy int term; /重修学期 double resmark; /重修分数restudy; 2.4 界面设计程序界面应遵循简洁美观、方便使用的原则。主界面充分考虑界面易于操作的系统需求,用printf语句构造简单的文字界面,具体主界面设计效果如图所示。新增信息界面根据相关的文字提示,用户输入对应信息。 3. 系统实现基于系统需求分析与系统总体设计的结果,本系统采用Code:Blocks12.11软件平台基于C语言实现各模块的功能,下面按照模块的功能划分来分别阐述系统的详细设计和实现过程。3.1头文件:#include #include #include 3.2主界面模块功能:功能选择界面输入:用户选择的功能选项编号处理:根据用户选项跳转到相关功能函数输出:相关功能函数的处理或显示界面程序清单:student *insstu(); /加载学生信息及其课程成绩student *inspoint(student *head,student *stud); /插入链表结点void clalesmark(student *head); /按班统计学生选课情况及考试成绩void lesstumark(student *head); /按课程统计学生名单及考试成绩void pointfail(student *head); /统计并输出每个同学已修学分及不及格课程student *adds(student *hd); /新增学生信息及其课程成绩student *savestu(student *head); /保存学生信息及其课程成绩int main(void) student *head,*p; int num,n; int size=sizeof(struct student); head=NULL; printf(tt*欢迎使用教务信息管理系统*); do printf(ntt* -请选择- *n); printf(tt* 1、加载学生信息及其课程成绩ttt2、新增学生信息及其课程成绩 *n); printf(tt* 3、按班统计学生选课情况及考试成绩tt4、按课程统计学生名单及考试成绩 *n); printf(tt* 5、统计并输出每个同学已修学分及不及格课程t6、保存学生信息及其课程成绩并退出*n); printf(tt* -0、退出- *nn); fflush(stdin); /清除缓冲区 scanf(%d,&n); switch(n) case 1:head=insstu();break; case 3:clalesmark(head);break; case 4:lesstumark(head);break; case 5:pointfail(head);break; case 2:head=adds(head);break; case 6:savestu(head);break; default :break; while(n!=0&n!=6); printf(ntt* -!谢谢使用!- *n); return 0;3.3加载信息模块功能:从根文件夹加载记录学生信息的文件输入:无处理:将所有学生信息形成链表输出:加载成功情况程序清单:student *insstu() student *p,*hd,*pt; int i,j,n=0; FILE *fp; fp = fopen( stu.txt , r ); /从根目录读取文件 int size=sizeof(student); hd=NULL; while(1) p=(student *)malloc(size); fscanf(fp,%s,&p-stun); /读取学号 if(strcmp(p-stun,0)=0)break; /学号为0返回 fscanf(fp,%d,&p-cla); /读取班级 fscanf(fp,%s,&p-name); /读取姓名 fscanf(fp,%s,&p-sex); /读取性别 fscanf(fp,%d,&p-age); /读取年龄 fscanf(fp,%s,&p-dorn); /读取宿舍号码 fscanf(fp,%s,&p-phon); /读取短号电话号码 p-sub=0;p-poi=0; for(i=p-sub;ilesi.lessonn); /读取课程编号 if(strcmp(p-lesi.lessonn,0)=0)break; /课程编号为0返回 fscanf(fp,%s,&p-lesi.lessonname); /读取课程名称 fscanf(fp,%lf,&p-lesi.textmark); /读取考试成绩 fscanf(fp,%lf,&p-lesi.formalmark); /读取平时成绩 fscanf(fp,%lf,&p-lesi.mark); /读取综合成绩 fscanf(fp,%lf,&p-lesi.point); /读取学分 p-poi+=p-lesi.point; /将该课程学分加入已修总学分 fscanf(fp,%s,&p-lesi.re); /读取是否重修 if(strcmp(p-lesi.re,是)=0) fscanf(fp,%d,&p-lesi.restime); /读取重修次数 for(j=0;jlesi.restime;j+) fscanf(fp,%d,&p-lesi.resj.term); /读取重修学期 fscanf(fp,%lf,&p-lesi.resj.resmark); /读取重修成绩 p-sub+; n+; if(n=1) hd=p;pt=p; else pt-next=p;pt=p; pt-next=NULL; printf(加载学生数据成功!共加载%d位学生信息n,n); return hd;3.4新增信息模块功能:增加学生,并完整录入相关个人信息及选课信息输入:学生信息处理:将所得学生信息插入链表输出:无程序清单:student *adds(student *hd) student *p,*q,*r; int i,j; int size=sizeof(student); while(1) p=(student *)malloc(size); /hd=inspoint(hd,p); /p-next=NULL; printf(请输入学号(12位数字,返回请输入0):); scanf(%s,&p-stun); if(strcmp(p-stun,0)=0)break; printf(请输入班级号(软件R( )班):); scanf(%d,&p-cla); printf(请输入姓名:); scanf(%s,&p-name); printf(请输入性别:); scanf(%s,&p-sex); printf(请输入年龄:); scanf(%d,&p-age); printf(请输入宿舍号码(5位数字):); scanf(%s,&p-dorn); printf(请输入电话号码(短号):); scanf(%s,&p-phon); p-sub=0;p-poi=0; for(i=p-sub;ilesi.lessonn); if(strcmp(p-lesi.lessonn,0)=0)break; printf(请输入课程名称:); scanf(%s,&p-lesi.lessonname); printf(请输入考试成绩:); scanf(%lf,&p-lesi.textmark); printf(请输入平时成绩:); scanf(%lf,&p-lesi.formalmark); printf(请输入综合成绩:); scanf(%lf,&p-lesi.mark); printf(请输入学分:); scanf(%lf,&p-lesi.point); p-poi+=p-lesi.point; printf(是否需要重修(输入“是,否”,):); scanf(%s,&p-lesi.re); if(strcmp(p-lesi.re,是)=0) printf(请输入重修次数:); scanf(%d,&p-lesi.restime); for(j=0;jlesi.restime;j+) printf(请输入重修学期:); scanf(%d,&p-lesi.resj.term); printf(请输入重修成绩:); scanf(%lf,&p-lesi.resj.resmark); p-sub+; hd=inspoint(hd,p); /插入一个新结点以继续增加学生人数 p-next=NULL; system(cls); /清屏 return hd;3.5按班级统计模块功能: 按班级有序地查看学生的情况输入:无处理:按班级R1R10分类统计学生信息输出:输出学生所有信息到屏幕和文件”case3.txt”程序清单:void clalesmark(student *head) /同时输出数据到屏幕和文件 int i,j,k; student *s; FILE *fp; fp = fopen( case3.txt , w ); /输出文件到根目录 if(head=NULL) fprintf(fp,没有信息。n);printf(没有信息。n); else fprintf(fp, 学号 姓名 性别 年龄 宿舍号 电话号码 课程编号 课程名称 平时成绩 考试成绩 综合成绩 学分 是否重修 重修次数 重修情况n); printf( 学号 姓名 性别 年龄 宿舍号 电话号码 课程编号 课程名称 平时成绩 考试成绩 综合成绩 学分 是否重修 重修次数 重修情况n); printf(-n); fprintf(fp,-n); for(i=1;icla=i) fprintf(fp,%13s %8s %s %d%9s%10sn,s-stun,s-name,s-sex,s-age,s-dorn,s-phon); printf(%13s %8s %s %d%9s%10sn,s-stun,s-name,s-sex,s-age,s-dorn,s-phon); for(j=0;jsub;j+) fprintf(fp, %s %12s %5.1lf %5.1lf %5.1lf %3.1lf %s,s-lesj.lessonn,s-lesj.lessonname,s-lesj.formalmark,s-lesj.textmark,s-lesj.mark,s-lesj.point,s-lesj.re); printf( %s %12s %5.1lf %5.1lf %5.1lf %3.1lf %s,s-lesj.lessonn,s-lesj.lessonname,s-lesj.formalmark,s-lesj.textmark,s-lesj.mark,s-lesj.point,s-lesj.re); if(strcmp(s-lesj.re,是)=0) fprintf(fp, %d ,s-lesj.restime);printf( %d ,s-lesj.restime); for(k=0;klesj.restime;k+) fprintf(fp,/第%d次:第%d学期,%.1lf分/,k+1,s-lesj.resk.term,s-lesj.resk.resmark); printf(/第%d次:第%d学期,%.1lf分/,k+1,s-lesj.resk.term,s-lesj.resk.resmark); fprintf(fp,n);printf(n); s=s-next; 3.6按课程统计模块功能: 按课程查看已修该课的学生的成绩情况输入:课程编号处理:逐个学生查找是否已修该课程 输出:输出学生成绩情况到屏幕和文件”case4.txt”程序清单:void lesstumark(student *head) int i; char lessonn15; student *s; FILE *fp; fp = fopen( case4.txt , w ); if(head=NULL) fprintf(fp,没有信息。n);printf(没有信息。n); else while(1) printf(请输入课程编号(返回请输入0):); scanf(%s,&lessonn); if(strcmp(lessonn,0)=0)break; fprintf(fp,ntt 课程名称 学号 姓名 平时成绩 考试成绩 综合成绩 学分 是否重修n); printf(ntt 课程名称 学号 姓名 平时成绩 考试成绩 综合成绩 学分 是否重修n); fprintf(fp,tt-n); printf(tt-n); s=head; while(s!=NULL) for(i=0;isub;i+) if(strcmp(s-lesi.lessonn,lessonn)=0) /查找该学生是否已修该课 fprintf(fp,tt%12s %13s %8s %5.1lf %5.1lf %5.1lf %3.1lf %sn,s-lesi.lessonname,s-stun,s-name,s-lesi.formalmark,s-lesi.textmark,s-lesi.mark,s-lesi.point,s-lesi.re); printf(tt%12s %13s %8s %5.1lf %5.1lf %5.1lf %3.1lf %sn,s-lesi.lessonname,s-stun,s-name,s-lesi.formalmark,s-lesi.textmark,s-lesi.mark,s-lesi.point,s-lesi.re); break; s=s-next; fprintf(fp,n); printf(n); 3.7输出已修学分及不及格课程模块功能: 查看所有学生已修学分及不及格课程输入:无处理:从头到尾检索每个学生已修学分及不及格课程 输出:输出所有学生已修学分及不及格课程到屏幕和文件”case5.txt”程序清单:void pointfail(student *head) int i; char lessonn15; student *s; FILE *fp; fp = fopen( case5.txt , w ); if(head=NULL) fprintf(fp,没有信息。n);printf(没有信息。n); else fprintf(fp,tt 学号 姓名 班级 已修学分 不及格课程n);printf(tt 学号 姓名 班级 已修学分 不及格课程n); fprintf(fp,tt-n);printf(tt-n); s=head; while(s!=NULL) fprintf(fp,tt%11s %8s %d %.1lf ,s-stun,s-name,s-cla,s-poi); printf(tt%11s %8s %d %.1lf ,s-stun,s-name,s-cla,s-poi); for(i=0;isub;i+) if(s-lesi.marklesi.lessonname);printf(%s ,s-lesi.lessonname); fprintf(fp,n);printf(n); s=s-next; 3.8保存信息模块功能:保存当前学生信息输入:无处理:将原有学生信息及新增学生信息写出到根目录的文件,并覆盖原来的文件输出:保存成功情况程序清单:student *savestu(student *head) student *p; int i,j,n=0; FILE *fp; fp = fopen( stu.txt , w ); /写出到根文件夹的文件,并覆盖原有文件 p=head; while(p!=NULL) fprintf(fp,%sn,p-stun); if(strcmp(p-stun,0)=0)break; fprintf(fp,%dn,p-cla); fprintf(fp,%sn,p-name); fprintf(fp,%sn,p-sex); fprintf(fp,%dn,p-age); fprintf(fp,%sn,p-dorn); fprintf(fp,%sn,p-phon); p-sub=0;p-poi=0; for(i=p-sub;ilesi.lessonn); if(strcmp(p-lesi.lessonn,0)=0)break; fprintf(fp,%sn,p-lesi.lessonname); fprintf(fp,%lfn,p-lesi.textmark); fprintf(fp,%lfn,p-lesi.formalmark); fprintf(fp,%lfn,p-lesi.mark); fprintf(fp,%lfn,p-lesi.point); p-poi+=p-lesi.point; fprintf(fp,%sn,p-lesi.re); if(strcmp(p-lesi.re,是)=0) fprintf(fp,%dn,p-lesi.restime); for(j=0;jlesi.restime;j+) fprintf(fp,%dn,p-lesi.resj.term); fprintf(fp,%lfn,p-lesi.resj.resmark); p-sub+; n+; p=p-next; fprintf(fp,0); /为了下次能加载该文件成功,需要加上0作为退出标志 printf(保存学生数据成功!共保存%d位学生信息n,n); return p; 4. 系统测试 4.1 主界面测试输入0-6:系统执行指定操作。输入其他数字或字符(串):清屏并重新显示主界面。 4.2 无加载信息情况下各功能模块测试选择输入2:建立一个新链表,并连接输入的数据。选择输入3,4,5:因链表为空,提示“没有信息”,并返回主界面。选择输入6:写出一个空文件,原有数据丢失! 4.3 新增学生功能模块测试按提示输入: 学号输入0:返回到主界面。课程编号输入0:课程信息输入结束,继续跳到输入学号步骤。是否需要重修:输入 是:继续执行,按提示输入重修情况。输入 否:进入下一门课程输入步骤。输入其他字符:进入下一门课程输入步骤。 4.4 按课程统计功能模块测试输入数字串:显示标题栏,若查找到已修该课的学生,输出该学生成绩情况。输入其他字符:只显示标题栏。输入0:返回到主界面。 5. 系统运行界面5.1 初始界面5.2 加载界面5.3 新增学生界面5.4 按班级统计界面5.5 按课程统计界面5.6 输出已修学分及不及格课程界面5.7 保存界面5.8 退出界面 6. 总结本课程设计进行了教务信息管理系统的分析、设计、实现。主要运用C语言实现在EXE程序下对学生基本信息、选课信息、重修情况进行数据录入和整理。并通过文件实现对数据的读写操作。本次课程设计,编写程序耗费了我大概半个月的时间,由于对C语言链表和文件部分知识掌握的不够透彻,期间多次查阅课本及从互联网搜索相关知识。不得不说,在此之前,我对C语言知识的掌握程度主要还停留在理论的级别,上机实践操作也仅仅懂得最基本的操作。通过本次程序设计实习,我学会了更深层次的知识,体会到了C语言的魅力所在。同时,本次课程设计的征程也并非一帆风顺,由于知识有限,途中无数次遇到调试出错、功能实现失败、输出死循环、程序强制停止运行等情况,失败乃成功之母,我通过互联网向网友求助、搜索文库资料,向同学和老师咨询等等途径,最终将难题一一解决。正如马克思所说:“生活就像海洋,只有意志坚强的人才能到达成功的彼岸。”如今,我终于尝到成功的滋味,敲代码的日子的确很煎熬,但在这段日子里,我学到了很多的东西,我觉得这段日子十分有意义,同时更加同意“实践是检验理论的唯一途径”这一观点。由于知识和时间的局限,本程序仍存在功能的不足和未知BUG,比如学生信息的修改和删除功能的缺失,造成对错误数据无法进行处理,对用户操作带来不便。我对此表示遗憾,我会继续巩固并强化我的专业知识,为以后的类似情况做好准备。不管怎样,这是我编写的第一个程序,尽管略显简陋,但我仍有很大的成就感,同时感谢给我提供帮助的同学老师和网友,我会再接再厉,迎接更大的挑战。7.参考文献C语言程序设计(第2版) 何钦铭 颜晖 著
展开阅读全文
相关资源
相关搜索

最新文档


当前位置:首页 > 图纸专区 > 中学资料


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!