学生信息管理系统C语言课程设计报告.doc_第1页
学生信息管理系统C语言课程设计报告.doc_第2页
学生信息管理系统C语言课程设计报告.doc_第3页
学生信息管理系统C语言课程设计报告.doc_第4页
学生信息管理系统C语言课程设计报告.doc_第5页
已阅读5页,还剩37页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

精品文档课 程 设 计 报 告 学 院:软件学院 课程名称:学生信息管理系统 专业班级:软件工程 姓 名:袁傲 学 号:10203542 目 录一、需求分析1.总体功能设计1.各模块功能设计1二、总体模块功能框图2三、总流程图及各模块流程图2四、各模块主要功能的实现5显示模块5追加模块6查询模块6删除模块6修改模块6排序模块6五、程序调试7显示程序7追加程序8查询程序10删除程序13修改程序14排序程序17六、总结与心得体会19七、附件20.源程序20.注释30一、需求分析:.总体功能设计: 学生信息管理系统存放了每个学生的学号、姓名、性别、年龄、出生年月日、地址、电话号码、E-mail信息地数据库。每个人的信息定义在一个结构体变量中。其结构如下:系统通过显示程序、追加程序、查询程序、删除程序、修改程序、排序程序来实现学生信息管理系统的显示功能、追加功能、查询功能、删除功能、修改功能、排序功能。各个功能的调用通过主函数中的switch语句来实现。.各模块功能:.显示模块:通过设计一个模块,来实现学生信息的显示。以便于浏览学生的信息。 .追加模块: 通过设计一个模块,当要加入新的学生的信息的时候,来实现新学生信息的加入。iii.查询模块: 通过设计一个模块,这个模块可以按学生的学号、姓名来查询学生所有的信息,并显示学生的所有信息,以便查询者阅读。 iv.删除模块: 通过设计一个模块,当输入一个学生的学号或者姓名的时候,可以通过这个模块,将输入学号或者姓名的学生的所有信息从数据库中删除出去。以后,这个学生的信息将不再会出现再数据库中。v.修改模块:通过设计一个模块,当某个人的信息发生变化的时候,可以通过修改模块来进行修改。修改模块时一具有多级子菜单的摸块。使用十分的方便、灵活。vi.排序模块:通过设计一个模块,来实现数据库的信息按某项成员名的伸序或者降序排列。这个模块提供了按学号、姓名、年龄三种方式来实现排序,使浏览者一目了然。二.总体模块框图: 主函数显示模块追加模块删除模块查询模块排序模块退出模块修改模块退出三、总流程图及各模块流程图.总流程图:进入输入Sele=?追加程序删除程序查询程序排序程序显示程序退出程序输出Sele=7Sele=3Sele=2Sele=4Sele=6Sele=1退出.各模块流程图:.删除程序:进入输入M=?输入学号输入姓名输出所有退出M=1M=2.查询程序:进入输入M=?输入学号输入姓名输出查询结果退出M=2M=1四、各模块主要功能的实现I.显示模块程序通过一个printf函数把输出信息的表头打印出来,再通过一个for循环把每一个学生的信息输出,再输出的时候,通过定义数字、字符的长度大于本身的长度来实现输出信息的排版和隔开,使输出的信息排版美观。II.追加模块程序通过输入一个整型变量n的值来确定追加的个数,再通过一个for循环来实现n个新数据的追加。每个结构体中间的成员之间用空格来隔开,各个结构体之间通过回车键来隔开。III.查询模块程序通过输入一个变量n来实现是按学号还是按姓名来查找。当输入完学号或者姓名的时候,再通过一个for循环来实现此人信息的查找。当含有这个人的信息的时候,把变量k赋值为1,并把此人再内存的顺序号赋给i。如果不含这个人的信息的时候,变量k的值仍为0。再通过一个if 语句,如果k的值为1,则打印第j个人的所有信息,如果k的值为0,则打印“Error!”。IV删除模块程序通过定义一个变量n,来确定输入的到底是学号还是姓名。通过一个for循环来确定数据库到底是否含有此人的信息。如果含有此人的信息,则通过一个for循环,把这个以后的信息依次前推来覆盖这个人的信息,而实现此人信息的删除。如果不含此人的信息,则打印“Error!”。V修改模块 程序定义一个变量n,来确定到底输入的是学号还是姓名。通过一个for循环来确定数据库到底是否含有此人的信息。如果含有此人的信息,则把此人的信息打印再屏幕上。再显示二级菜单,是修改这个人的学号、姓名、性别、年龄、出生年月、地址、电话号码还是E-mail。通过一个switch语句来实现某个信息地修改。如果不含有此人的信息,则打印“Error!”。VI排序模块:程序通过定义一个变量n来输入一个变量,来确定是按学号、姓名还是年龄来排序。首先定义一个结构体变量作为中间变量。学号排序,通过两重for循环,运用中间结构体变量来实现两个变量信息的交换。首先把学号最小的放第一个,以后依次类推。姓名排序,同样通过双重for循环,通过strcmp函数来实现两个字符串的比较,再实现两个信息的交换。年龄排序,也是同样的方法,不过是按年龄的伸序排列。五程序调试I.显示程序:1如果运行程序,将出现如下的界面:图1-12此时如果输入1,并按回车键,程序将进入显示模块,通过显示模块显示所有学生的所有信息。其输出界面如下: 图12II追加程序:1 当在图11的前提下输入2,则进入追加模块,此时则出现如下的界面:图2-12此时电脑在问你要追加的人数,如果你输入1,则出现如下的界面:图2-23这个时候你就将追加这个学生的信息输入,输入如下信息:4 liu m 44 19910101 beijing2789qq输入完后将出现以下界面:图2-34信息追加完以后,程序会自动跳到显示模块,把数据库种的信息再输出一次。将会出现如下界面:图2-4III查询程序:1 如果再图1-1的基础上选择5,则进入查询模块,进入如下的界面:图3-12如果你选择1,则将进入按学号查询的界面。如下:图3-23如果你输入4,电脑将会自动查询学号为4学生的信息,并显示在屏幕上。如下:图334如果你在图3-1的基础上选择2,并在输入了yuan,则会出现如下的界面:图345如果你在图32和图34输入后,查无此人。则显示如下信息:图3-5IV删除程序:1如果你在图11的界面下选择4,则进入删除程序,出现如下界面:图412如果你选择1,并在此基础上输入学号2,程序则将学号为2的人信息删除,并显示如下:图4-23如果你在图41的基础上选择2,并输入yuan,则出现如下界面:图43V.修改程序:1.如果你在图11 下选择3,则进入修改程序,出现是按学号还是按姓名修改,如选择 1,则出现如下:图5-12.如输入学号 3,出现下一级菜单,选择修改的内容,界面如下:图5-23.如选择2,并输入xiangning,则将学号为112的人的姓名改为xiangning,界面如下:图5-34. 如果你在图51下选择3,并输入liu,则将出现如下界面:5.如果你选择1,并输入11,则姓名为liu的人的学号将改为11,界面如下:图5-5VI.排序程序:1.如果你在图11 界面下选择6,则进入排序程序,你将选择是按学号、姓名还是年龄排,其界面如下:图6-12.如选择1,则按学号排,其结果如下:图6-23.如果在图61界面下选择2,则将按姓名排,其结果如下:图6-34.如果在图61界面下选择3,则将按年龄排,年龄相同则按学号排,其结果如下:图6-45.如在11界面下选择7,则将进入退出程序,其界面如下:图6-5六.总结与心得体会 由于c语言的知识相对缺乏,在设计这个程序时,刚开始是根据在网上给提供的资料,用画图以及循环将框架设计出来,但是接下去便无从下手了,构架是个关键和难点,也查了相应的资料,通过自学,这构架问题解决了。具体的函数还需要一步一步的慢慢编写,虽然在编译的时候会出现许多的错误,有时候修改时觉得很繁琐,但是这些只要你自己愿意坚持,去尝试,最后问题都迎刃而解。在这一个多星期的设计过程中,经过拼搏与努力,终于运行出程序,也让我知道成功的难能可贵,总之,这次设计程序让我受益良多,我会好好珍惜像这种难得的机会 七.附件(源程序)/*学生信息管理系统应能提供以下功能:系统以菜单方式工作学生信息显示功能学生信息追加功能学生信息查询功能学生信息的删除学生信息的修改按学生年龄排序*/#include stdio.h#include string.h#include conio.hint N=0;struct stu long int num; /*学号*/ char name10; /*姓名*/ char sex4; /*性别*/ int age; /*年龄*/ char brithday10; /*出生年月*/ char address10; /*地址*/ char phone15; /*电话号码*/ char e_mail20; /*E-mail*/ s40;void Re_file() FILE *fp; fp=fopen(E:xsxxk.txt,r); while( fscanf(fp,%ldn%sn%sn%dn%sn%sn%sn%sn,&sN.num,sN.name,sN.sex,&sN.age,sN.brithday,sN.address,sN.phone,sN.e_mail)!=EOF) N+; fclose(fp); void Wr_file()int i; FILE *fp; fp=fopen(E:xsxxk.txt,w); for(i=0;iN;i+) fprintf(fp,%ldn%sn%sn%dn%sn%sn%sn%sn,si.num,,si.age,si.age,si.brithday,si.address,si.phone,si.e_mail); fclose(fp);void Disp() /*显示模块*/ int i; printf(*n); printf( num name sex age brithday address phone e-mailn); printf(*n); for(i=0;iN;i+) printf(%-4ld%-11s%-7s%-4d%-11s%-11s%-13s%-19sn,si.num,,si.sex,si.age,si.brithday,si.address,si.phone,si.e_mail);void Appe() /*追加模块*/ int n,i; printf( *n); printf( n); printf( input n= ? n); printf( n); printf( *n); scanf(%d,&n); printf( *n); printf( * *n); printf( * continue! *n); printf( * *n); printf( *n); printf(*n); printf( num name sex age brithday address phone e-mailn); printf(*n); for(i=0;in;i+) scanf(%ld%s%s%d%s%s%s%s,&sN.num,sN.name,sN.sex,&sN.age,sN.brithday,sN.address,sN.phone,sN.e_mail); N+; void Modi() /*修改模块*/ int m,n,x,k=0,i,j,t;char st20; printf( *n); printf( * 1.xuehao *n); printf( * *n); printf( * 2.name *n); printf( *n); scanf(%d,&m); if(m=1) printf( *n); printf( * *n); printf( * Please input xuehao! *n); printf( * *n); printf( *n); scanf(%d,&n); for(i=0;iN;i+) if(n=si.num) k=1;j=i; else if(m=2) printf( *n); printf( * *n); printf( * Please input name! *n); printf( * *n); printf( *n); scanf(%s,st); for(i=0;iN;i+) if(!strcmp(,st) k=1;j=i; if(k=1) printf( *n); printf( * *n); printf( * 1.xuehao 2.name *n); printf( * *n); printf( * 3.sex 4.age *n); printf( * *n); printf( * 5.date 6.address *n); printf( * *n); printf( * 7.phone 8.e-mail *n); printf( * *n); printf( *n); scanf(%d,&x); switch(x) case 1: scanf(%d,&t);sj.num=t; break; case 2: scanf(%s,st);strcpy(,st); break; case 3: scanf(%s,st);strcpy(sj.sex,st); break; case 4: scanf(%d,&t);sj.age=t; break; case 5: scanf(%s,st);strcpy(sj.brithday,st); break; case 6: scanf(%s,st);strcpy(sj.address,st); break; case 7: scanf(%s,st);strcpy(sj.phone,st); break; case 8: scanf(%s,st);strcpy(sj.e_mail,st); break; else printf( *n); printf( * *n); printf( * Eorr! *n); printf( * *n); printf( *n); void Dele() /*删除模块*/ int m,n,k=0,j,i; char str10; printf( *n); printf( * 1.xuehao *n); printf( * *n); printf( * 2.name *n); printf( *n); scanf(%d,&m); if(m=1) printf( *n); printf( * *n); printf( * Please input xuehao! *n); printf( * *n); printf( *n); scanf(%d,&n); for(i=0;iN;i+) if(n=si.num) k=1;j=i; else if(m=2) printf( *n); printf( * *n); printf( * Please input name! *n); printf( * *n); printf( *n); scanf(%s,str); for(i=0;iN;i+) if(!strcmp(,str) k=1;j=i; if(k=1) for(i=j;iN-1;i+) si=si+1; N-; else printf( *n); printf( * *n); printf( * Eorr! *n); printf( * *n); printf( *n); void Query() /*查询模块*/ int i,n,m,j,k=0; char str10; printf( *n); printf( * 1.xuehao *n); printf( * *n); printf( * 2.name *n); printf( *n); scanf(%d,&m); if(m=1) printf( *n); printf( * *n); printf( * Please input xuehao! *n); printf( * *n); printf( *n); scanf(%d,&n); for(i=0;iN;i+) if(n=si.num) k=1;j=i; else if(m=2) printf( *n); printf( * *n); printf( * Please input name! *n); printf( * *n); printf( *n); scanf(%s,str); for(i=0;iN;i+) if(!strcmp(,str) k=1;j=i; if(k=1) printf(*n); printf( num name sex age brithday address phone e-mailn); printf(*n); printf(%-4ld%-11s%-7s%-4d%-11s%-11s%-13s%-19sn,sj.num,,sj.sex,sj.age,sj.brithday,sj.address,sj.phone,sj.e_mail); else printf( *n); printf( * *n); printf( * Eorr! *n); printf( * *n); printf( *n); void Sort() /*排序*/ int m,i,j; struct stu temp; printf( *n); printf( * 1.xuehao *n); printf( * 2.name *n); printf( * 3.age *n); printf( *n); scanf(%d,&m); if(m=1) for(i=0;iN-1;i+) for(j=i+1;jsj.num) temp=si;si=sj;sj=temp; else if(m=2) for(i=0;iN-1;i+) for(j=i+1;j0) temp=si;si=sj;sj=temp; else if(m=3) for(i=0;iN-1;i+) for(j=i+1;jsj.age) temp=si;si=sj;sj=temp; else if(si.age=sj.age) if(si.numsj.num) temp=si;si=sj;sj=temp; else printf( *n); printf

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论