c语言课程设计学生学籍信息管理系统.doc
《c语言课程设计学生学籍信息管理系统.doc》由会员分享,可在线阅读,更多相关《c语言课程设计学生学籍信息管理系统.doc(25页珍藏版)》请在咨信网上搜索。
学年论文 (课程论文、课程设计) 题 目:学生学籍信息管理系统 作 者: 所在学院: 信息科学与工程学院 专业年级: 指导教师: 职 称: 讲师 2014年 12月 31日 目录 1. 设计内容、任务以及要求.......................... 1.1设计内容、任务 1.2 设计要求 2. 设计思路概述.................................... 2.1 系统基本功能 2.2 具体设计思想 2.3 系统的总体流程图 3. 函数设计的实现.............................. 3.1 结构的定义 3.2 各个函数的设计简介 3.3源代码 3.4删除模块的详细介绍 4. 重点程序的调试及运行............................ 删除函数的测试 5. 总结............................................ 6. 致谢............................................ 7. 参考文献........................................ 1. 设计内容、任务以及要求 1.1 设计内容、任务 主要利用c语言的文件操作能力设计开发一个学生学籍管理系统,至少具有如下功能:信息输入、输出、查找、删除、成绩排序等功能。具体内容如下: (1) 通过提示菜单选择可以进行的操作; (2) 将学生的信息存入文件中,并命名为txl.txt; (3) 在本系统中可以进行管理系统包含的基本操作: a. 查看所有学生信息; b. 输入一个学生的姓名或学号,从当前的信息中查找,如果找到则显示该学生的相关信息,如果没找到则给出相关提示信息; c. 输入一个学生的姓名或学号,从当前信息中查找,如果找到则删除该学生的基本信息,如果没找到则给出相关提示信息; d. 将学生的成绩按降序排序; Txl.txt文件中: (4) 学生基本信息包括:学号、姓名、性别、班级、籍贯、分数等简单信息; 1.2设计要求 明确课程设计的目的,能根据课程设计的要求,查阅相关文献,为完成设计准备必要的知识;提高学生用高级语言进行程序设计的能力,重点提高用c语言进行文件操作的编程技术水平;初步了解软件开发的一般方法和步骤。 2. 设计思路概述 2.1 系统基本功能 外部操作:根据要求系统要有查看全部学生信息,查找、添加、删除某一个学生信息; 内部操作:将学生的信息存入文件中,并命名为txl.txt; 为了接近实际学生学籍管理系统,增加了一个权限认证功能(使用前需要输入正确的账号及密码)。 2.2 具体设计思想 (1) 以结构化各个功能模块,函数间的调用精简整个函数; (2) 以全局结构来随时定义结构数组及其结构; (3) 以写一个信息存一个的思想,实现多个添加功能; (4) 以先全部读入内存,再打印信息的思想,实现显示全部信息; (5) 以先判断再打印的思想,实现查找是否有某一学生信息; (6) 以先判断再删除的思想,实现删除某一学生信息; (7) 以选择排序算法的思想,实现学生成绩的排序 2.3 系统的总体流程图 权限确认 进入系统 检索信息 选择菜单 输出信息 退出程序 成绩排序 建立档案 删除信息 按学号查找 按姓名查找 按姓名查找 按学号查找 3.函数设计的实现 3.1 结构的定义及宏定义 为了方便使用结构此系统结构全为全局类型定义,如下: struct student_info {char no[11]; int age; enum SEX sex; char name[20]; int classno; float grade; char nationality[20]; }; typedef struct student_info STUINFO; STUINFO txl[100]; 宏定义 #define A 1 #define B 2 #define C 3 #define D 4 #define E 5 #define F 0 全局变量 int last=0; 3.2各个函数的设计简介 此系统一共十九个函数如下所示 1) int Key(char,char); 比较判断账户名和账户密码是否正确 2)int ck(void); 显示提示窗口提示密码或者账户名错误,用鼠标回到程序 3)void getpassword(); 密码函数 4)void findchoice(); 检索模块中的选择查找方式的函数 5)void findmenu(); 显示查找或删除菜单界面 6)void numfind(); 实现按学号查找并输出功能 7)void namfind(); 实现按姓名查找并输出功能 8)void Establish(); 将学生信息写入内存并保存入文件 9)void dochoice(int); 接受用户的选择,并启动相应函数 10)void mainmenu(); 显示主菜单 11)void Bead(); 将文件读取到内存中 12)oid Write(); 将内存中的学生信息写入文件中 13)int getchoice(); 接受用户的选择键,并传送至dochoice(int)函数 14)void Sort(); 实现排序功能 15)void Outputall(); 输出全部信息 16)void findchoicedelete(); 17)void Numdelete(); 实现按学号删除功能 18)void Namdelete(); 实现按姓名删除功能 19) int main(int argc,char *argv[]) 主函数实现调用所有其他函数功能 3.3源代码 #include <stdio.h> #include <string.h> #include <stdlib.h> #include <memory.h> #include <conio.h> #include <windows.h> #define A 1 #define B 2 #define C 3 #define D 4 #define E 5 #define F 0 FILE *fp; enum SEX {male,female}; struct student_info {char no[11]; int age; enum SEX sex; char name[20]; int classno; float grade; char nationality[20]; }; typedef struct student_info STUINFO; STUINFO txl[100]; int last=0; int Key(char,char); int ck(void); void getpassword(); void findchoice(); void findmenu(); void numfind(); void namfind(); void Establish(); void dochoice(int); void mainmenu(); void Bead(); void Write(); int getchoice(); void Sort(); void Outputall(); void findchoicedelete(); void Numdelete(); void Namdelete(); int main(int argc,char *argv[]) {int choice; getpassword(); Bead(); while(1) {mainmenu(); choice=getchoice(); dochoice(choice); system("pause>nu1");} return 0; } void Bead() //从文件中把内容读取到内存中 {int i=0; if((fp=fopen("txl.txt","rb"))==NULL) {printf("文件读取失败,请检查文件是否存在!"); last=0; } else {while(!feof(fp)) { if(fread(&txl[i],sizeof(STUINFO),1,fp)==1) i++; } last=i; } fclose(fp); } void Write() //将内存中的内容写到文件中 {int i=0; if((fp=fopen("txl.txt","wb"))==NULL) {printf("文件储存失败,请检查文件是否存在!"); exit(0); } while(i<last) {fwrite(&txl[i],sizeof(STUINFO),1,fp); i++; } fclose(fp);} void mainmenu() //主菜单 {system("cls"); printf("\t\t ========欢迎进入新疆大学学籍管理系统========\n"); printf("\t\t 请选择以下操作:\n"); printf("\t\t 1.建立档案: 2.检索信息: \n"); printf("\t\t 3.输出全部信息: 4.排序: \n"); printf("\t\t 5.删除档案 0.退出 \n"); printf("\t\t ============================================"); printf("\n给出你的选择 0--5 \n"); } void Establish() //建立档案 {char sex; printf("第 %d 个学生的学号:\n",last+1); scanf("%s",&txl[last].no); printf("姓名:\n"); scanf("%s",&txl[last].name); printf("年龄:\n"); scanf("%d",&txl[last].age); printf("分数:\n"); scanf("%f",&txl[last].grade); printf("班级:\n"); scanf("%d",&txl[last].classno); printf("籍贯:\n"); scanf("%s",&txl[last].nationality); while(1) {fflush(stdin); //清除键盘缓存 printf("性别(m/f):\n"); scanf("%c",&sex); if(sex=='f'||sex=='m') break; fflush(stdin); } txl[last].sex=(sex=='m')? male :female; last++; Write();} void namfind() //按姓名查找 {char name[20]; int i; int find=0; printf("请输入姓名:"); scanf("%s",&name); for(i=0;i<last && !find;i++) { if(!strcmp(name,txl[i].name)) { find=1; printf("========================================\n"); printf("学号: %s\n",txl[i].no); printf("姓名: %s\n",txl[i].name); printf("年龄: %d\n",txl[i].age); printf("分数: %4.1f\n",txl[i].grade); printf("籍贯: %s\n",txl[i].nationality); printf("性别: %s",(txl[i].sex==male)? "male":"female"); } } if (!find) { printf("对不起,姓名:%s 没有被找到",name); } } void numfind() //按学号查找 { int i; char num1[12]; int find=0; printf("请输入您要查询的学号:"); scanf("%s",&num1); for(i=0;i<last && !find;i++) { if(!strcmp(num1,txl[i].no)) break; } if(i<last && !find) { printf("学号为%s的学生的基本信息为:\n",num1); printf("学号: %s\n",txl[i].no); printf("姓名: %s\n",txl[i].name); printf("年龄: %d\n",txl[i].age); printf("分数: %4.1f\n",txl[i].grade); printf("籍贯: %s\n",txl[i].nationality); printf("性别: %s",(txl[i].sex==male)? "male":"female"); printf("\n"); } else printf("您输入的学号不存在!\n");} int getchoice() //获得选择 {int choice; scanf("%d",&choice); return choice; } void dochoice(int choice)// { switch(choice) { case A:Establish();break; case B:findmenu();findchoice();break; case C: Outputall();break; case D:Sort();Outputall();break; case E:findmenu();findchoicedelete();break; case F:exit(0); } } void findchoice() //选择查找方式 { int m; while(1) { scanf("%d",&m); switch(m) { case 1: numfind(); findmenu();break; case 2: namfind(); findmenu();break; case 0:break; }if (m==0) break; }mainmenu();} void findmenu() //查找/删除界面 { printf("\t\t***********************************************\n"); printf("\t\t* 欢迎使用查找/删除操作 *\n"); printf("\t\t* 1.按学号查找/删除 *\n"); printf("\t\t* 2.按姓名查找/删除 *\n"); printf("\t\t* 0.返回上一级 *\n"); printf("\t\t***********************************************\n"); printf("\t\t请输入0--2: "); } void findchoicedelete() //选择删除方式 { int m; while(1) { scanf("%d",&m); switch(m) { case 2:Namdelete();findmenu();break; case 1:Numdelete(); findmenu();break; case 0:break; } if (m==0) break;} mainmenu();} void Sort() //排序 { int i,j,k;STUINFO p; for(i=0;i<last-1;i++) { k=i; for(j=i+1;j<last;j++) { if(txl[j].grade>txl[k].grade) k=j;} if(k!=i) {p=txl[i]; txl[i]=txl[k]; txl[k]=p; } } } void Outputall() //输出全部信息 {int i; printf(" 学号\t 年龄 姓名 性别 籍贯 分数\n" ); for(i=0;i<last;i++) {printf("%-s ",txl[i].no); printf("%-4d ",txl[i].age); printf("%-6s ",txl[i].name); printf(" %-4s ",(txl[i].sex==male)? "male":"female"); printf(" %-4s ",txl[i].nationality); printf(" %-4.1f ",txl[i].grade); printf("\n"); } } int Key(char p[20],char q[20]) {if(strcmp(p,"名字")==0&&strcmp(q,"nishengri")==0) return 0; else return 1; } void getpassword() {char p[20],q[20]; printf("请输入账号名-----------\n"); scanf("%s",&p); printf("请输入账号密码-----------\n"); scanf("%s",&q); Key(p,q); if (Key(p,q)==0) ; else {system("cls"); ck(); getpassword();} } void Namdelete() //按姓名删除 {char name[20]; int i,mark; int find=0; printf("请输入姓名:"); scanf("%s",&name); for(i=0;i<last && !find;i++) { if(!strcmp(name,txl[i].name)) { find=1; mark=i; break; } } if (!find) { printf("sorry,name:%s 没有输入!!",name); } else { for(i=mark;i<=last;i++) txl[i]=txl[i+1]; last--; Write();printf("删除成功!!\n");} } void Numdelete() //按学号删除 {char no[20]; int i,mark; int find=0; printf("请输入学号"); scanf("%s",&no); for(i=0;i<last && !find;i++) { if(!strcmp(no,txl[i].no)) { find=1; mark=i; break; } } if (!find) { printf("对不起,学号:%s 没有输入",no); } else { for(i=mark;i<=last;i++) txl[i]=txl[i+1]; last--; Write(); printf("删除成功.\n"); } } int ck(void) { MessageBox(NULL,"密码或用户名错误","错误提示",MB_OK); return 0; } 3.4删除模块的详细介绍 下面只重点介绍删除模块函数的设计与实现。 1) 功能介绍:删除函数主要是将已保存的某个学生信息删除,且保证其他学生的信息不受影响,适应于实际情况中的学生转学等其他特殊情况。 2) 设计思想:在c语言中,要想删除信息,只能利用覆盖思想,但为了不影响其他信息,要将后面的信息逐次往前覆盖,直到被删除信息的前一个人的信息。最后将删除调整后的新信息重新保存入文件中,覆盖原来的文件,从而达到将文件中某个信息删除的目的。 3) 具体设计 void findmenu() //查找/删除界面 { printf("\t\t************************************ ***********\n"); printf("\t\t* 欢迎使用查找/删除操作 *\n"); printf("\t\t* 1.按学号查找/删除 *\n"); printf("\t\t* 2.按姓名查找/删除 *\n"); printf("\t\t* 0.返回上一级 *\n"); printf("\t\t***********************************************\n"); printf("\t\t请输入0--2: "); } 先借用了检索函数的菜单,执行下面的程序 =============================================== void findchoicedelete() //选择删除方式 { int m; while(1) { scanf("%d",&m); switch(m) { case 2:Namdelete();findmenu();break; case 1:Numdelete(); findmenu();break; case 0:break; } if (m==0) break;} mainmenu();} 定义一个接受选择的变量m,利用switch的分支选择功能启动下一个函数—-利用姓名删除功能还是学号删除功能或是选择返回。同时利用死循环使该功能不断进行下去,直到用户主动退出。 =================================================== void Namdelete() //按姓名删除 {char name[20]; int i,mark; int find=0; printf("请输入姓名:"); scanf("%s",&name); for(i=0;i<last && !find;i++) { if(!strcmp(name,txl[i].name)) { find=1; mark=i; break; } } if (!find) { printf("sorry,name:%s 没有输入!!",name); } else { for(i=mark;i<=last;i++) txl[i]=txl[i+1]; last--; Write();printf("删除成功!!\n");} } 先定义一个数组 name[20]来存放查找的姓名,再定义计数变量i,标志变量mark,用来标记被删除信息的结构体数组下标;定义find来做显示是否查找到学生信息的标志。利用循环将文件中各个名字与所找名字做比较,如果有相同的或者比较完毕则跳出比较循环,找到相同的若则将所找下标赋给mark,将find的值改变,否则跳出循环。跳出后判断find是否改变,若没改变则输出提示信息表示没找到,否则从name[mark]将后面的信息依次向前覆盖,并将全局变量减一。最后调用Write()保存入文件,并输出提示信息。 =================================================== void Numdelete() //按学号删除 {char no[20]; int i,mark; int find=0; printf("请输入学号"); scanf("%s",&no); for(i=0;i<last && !find;i++) { if(!strcmp(no,txl[i].no)) { find=1; mark=i; break; } } if (!find) { printf("对不起,学号:%s 没有输入",no); } else { for(i=mark;i<=last;i++) txl[i]=txl[i+1]; last--; Write(); printf("删除成功.\n"); } 该函数与按姓名查找函数相似,只是将姓名比较改为学号比较,此处不再赘述。 4. 删除模块的测试 先显示主菜单 1. 先把文件中的所有信息输出一遍 2. 将学生朱佳辉的信息删除,选择5 3. 选择1,按学号删除 删除成功后 再测试若输入学号不对的情况 再看文件中的变化 删除前 删除后 5. 总结 经过小学期的程序设计学习,我们锻炼了动手能力和查阅文献资料的能力,巩固了c语言知识,基本掌握程序设计的基本方法和步骤。但更重要的是,通过大作业的练习,是我们充分感悟到c程序设计的本质是什么,要做好一个程序,基础知识必不可少,但更重要的是其思维方式,即算法思想,如果在动手之前心中没有一个略显雏形的算法,那么以下所做的一切都是浪费时间,所以思考永远是第一位。 6. 致谢 在这个为期六周的小学期中,我学到了很多知识,提高了自己的能力,这些都少不了老师的耐心指导。同时还有同学的帮助,帮我解决了很多困难,给我了很多鼓励,使我穿过了很多障碍,取得了很大进步。 还要感谢我的父母,是他们给了我机会来学习。 还要感谢所有为教育事业做出奉献的人。 7. 参考文献 [1]王敬华.c语言程序设计教程.清华大学出版社.2009. [2]王一萍.c程序设计与项目实践.清华大学出版社.2011. 新疆大学课程论文(设计)、学年论文评分表 题 目 作 者 专业年级 指导教师 指导教师评语及 评分建议 指导教师: 年 月 日 院 (部) 或 教 研 室 意 见 学院或教研室主任: 年 月 日 目 录 第一章 总 论 1 第二章 项目提出的背景和必要性 4 第一节 项目建设背景 4 第二节 项目建设的必要性 4 第三节 项目建设的先进性 8 第三章 市场分析与建设规模 10 第一节 市场分析 10 第二节 建设规模 11 第四章 工艺技术方案及设备选型 12 第一节 工艺技术方案 12 第二节 主要设备方案 14 第五章 原料、辅助材料及燃料的供应 17 第一节 主要原材料、辅助材料及公用工程供应来源 17 第二节 主要公用工程用量及供应 18 第六章 厂址选择和建设条件 19 第一节 厂址选择 19 第二节 建设条件 19 第七章 总图运输、土建及公用工程 22 第一节 总平面布置及运输 22 第二节 土建方案 23 第三节 公用工程 24 第八章 节 能 29 第一节 用能标准及设计规范 29 第二节 项目能源消耗种类及消耗情况 30 第三节 项目节能措施及效果分析 31 第九章 环境保护 33 第十章 劳动安全卫生及消防 36 第一节 劳动安全卫生 36 第二节 消 防 38 第十一章 机构组织与人力资源配置 41 第十二章 工程进度安排 43 第十三章 投资估算和资金筹措 45 第十四章 财务评价 47 第十五章 风险分析 50 第一节 项目主要风险因素识别及应对措施 50 第二节 项目风险因素和风险程度分析表 51 第十六章 结论与建议 54- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言 课程设计 学生 学籍 信息管理 系统
咨信网温馨提示:
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【快乐****生活】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【快乐****生活】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【快乐****生活】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【快乐****生活】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
关于本文