实验室设备管理系统_第1页
实验室设备管理系统_第2页
实验室设备管理系统_第3页
实验室设备管理系统_第4页
实验室设备管理系统_第5页
已阅读5页,还剩14页未读 继续免费阅读

下载本文档

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

文档简介

1、宁 波 工 程 学 院2015 2016 学年第 二 学期电信学院C语言课程设计报告题 目: 实验室设备管理系统 班 级: 计科152 姓 名: 孔庆康 学 号:指导教师: 洪立 2016 年 6 月目录目录21、系统功能和结构31.1系统设计目的31.2系统功能分析31.3系统结构分析42、核心技术介绍43、函数功能介绍54、设计体会及总结12参考文献:121、 系统功能和结构1.1系统设计目的 因为现在各个高校内教学设备众多但自动管理水平相比过低,很多高校管理设备都采用在设备购进以后将设备的基本情况和相关信息登记存档。存档以后档案基本就没人记录与维护,至于以后设备

2、的变迁或损坏都不会记录在设备档案中,即不能体现设备的即时状态。而有些即使有设备管理系统的单位,就算是能把设备的即时信息体现在设备档案上,但设备的缺陷处理及设备缺陷等功能没有实施,设备检修的备品备件情况和检修成本核算没有实现,整个学校教学设备管理信息化仍处于较低水平。将管理任务分成小块,落实到个人并能随时查询设备当前情况和历史情况,对设备的可靠性分析有直接作用,使管理人员从手工计算、统计工作中解脱出来。1.2系统功能分析实验室设备信息用文件存储,提供文件的输入输出操作;要能够完成设备的录入和修改,需要提供设备添加和修改操作;实现对设备进行分类统计,需要提供排序操作;实现对设备的插叙需要提供查找操

3、作,设备的查询可根据设备编号、设备种类、设备名称、设备购入日期、正常设备(未报废的)等多种方式查询;另外还要提供键盘式选择菜单以实现功能选择。1.3系统结构分析根据上面的需求分析,可以将这个系统的设计分为以下模块 实验设备管理系统信息输入信息添加信息修改信息统计信息搜索2、 核心技术介绍主函数 流程图显示一系列功能选项输入n,判断n是否是0-6根据n的值调用各功能模块函数 NY 程序void main()Node *equip;FILE *fp;int flag;Node *p,*q; printf("tttt设备管理系统n"); equip=(Node*)malloc(s

4、izeof(Node); equip->next=NULL; p=equip; fp=fopen("设备管理系统","wb+"); q=(Node*)malloc(sizeof(Node); if(fread(q,sizeof(Node),1,fp) /将文件的内容放入接点中 q->next=NULL; p->next=q; p=q; /将该接点挂入链表中 fclose(fp); /关闭文件 while(1) printf("*目录*"); printf("n1添加记录n"); printf(&q

5、uot;n2修改记录n"); printf("n3显示记录n"); printf("n4统计分类记录n"); printf("n0*-EXIT-*n"); printf("请输入你要操作的序号:"); scanf("%d",&flag); switch(flag) case 0: printf("n>>>>>>>>>>提示:已经退出系统,ByeBye!n");break; case 1: Add(e

6、quip); break; /增加记录 case 2: Modify(equip); break;/修改记录 case 3: Disp(equip); break;/显示记录信息 case 4: Tongji(equip); break;/统计记录 default: printf("n>>>>>>>>>>提示:输入错误!n"); break; 3、 函数功能介绍 (1)输入模块 流程图输入设备的各项详细信息输入用户要输入设备的个数i将输入的信息存储到文件的中 程序 /*输入模块*/#include "st

7、dio.h"#include "stdlib.h"#include "string.h"struct shebeichar ID10; char name15; char kind15; char over15; char yesno10; char time10; char price10; ;typedef struct nodestruct shebei data;struct node *next; /建立一个链表。Node;void Add(Node *equip) /添加记录Node *p,*r,*s; char id10; /先用

8、于输入ID,也用于判断是否跳出循环r=equip;s=equip->next; /使s为第一个有用的结点while(r->next!=NULL) /这个循环的作用是使r为最后一个有用的结点r=r->next; /将指针置于最末尾while(1) printf(">>>>>>>>>>提示:输入0则返回主菜单!n"); printf("n请你输入设备ID号:"); scanf("%s",id); if(strcmp(id,"0")=0) br

9、eak; p=(Node *)malloc(sizeof(Node); /申请空间 strcpy(p->data.ID,id); printf("n请输入设备名称:"); scanf("%s",p->); printf("n请输入设备种类:"); scanf("%s",p->data.kind); printf("n请输入报废日期:"); scanf("%s",&p->data.over); printf("n请输入

10、设备是否报废:"); scanf("%s",&p->data.yesno); printf("n请输入设备购买时间:"); scanf("%s",&p->data.time); printf("n请输入设备价格:"); scanf("%s",&p->data.price); printf(">>>>>>>>>>提示:已经完成一条记录的添加。n"); p->ne

11、xt=NULL; r->next=p; /这一步是必需的,将p与先前的链表连起来构成一条新链表 r=p; /也是必需的.将r 又重设为新链的最后一个有用结点 (2)修改模块 需求分析 此模块可以根据客户需要对以记录在文件中的信息进行修改 流程图 输入要修改的设备编号是否找到该设备资料显示找到的记录,调用修改函数显示没有找到对该设备的信息进行修改返回主菜单返回主菜单y n 程序 /*修改模块*/ void Modify(Node *equip)/修改Node *p;char find20;if(!equip->next) printf("n>>>>&

12、gt;>>>>>提示:没有资料可以修改!n"); return;printf("请输入要修改的设备ID号:"); scanf("%s",find); p=equip->next; while(p!=NULL) if(strcmp(p->data.ID,find)=0) /如果找到的话返回的是符合要求 break; p=p->next; if(p) /若找到 int x; while(1) printf("完成修改请输入0否则输入任意数再进行修改:"); scanf("

13、%d",&x); if(x=0) break; printf("请输入新设备号(原来是 %s ):",p->data.ID); scanf("%s",p->data.ID); printf("请输入新设备名称(原来是 %s ):",p->); scanf("%s",p->); printf("请输入新设备设备种类名称(原来是 %s ):",p->data.kind); scanf("%s",p

14、->data.kind); printf("请输入新设备报废日期名称(原来是 %s ):",p->data.over); scanf("%s",p->data.over); printf("请输入新设备是否报废(原来是 %s ):",p->data.yesno); scanf("%s",p->data.yesno); printf("请输入新设备购买时间(原来是 %s ):",p->data.time); scanf("%s",p->

15、data.time); printf("请输入新设备价格(原来是 %s ):",p->data.price); scanf("%s",p->data.price); printf("n>>>>>>>>>>提示:该项记录资料已经成功修改!n"); else printf("n>>>>>>>>>>提示:你要修改的信息不存在!n"); 返回主菜单(3)统计模块 需求分析将已经输入的设备信息进

16、行统计,并显示设备总数、价格总额等信息流程图打开文件,并对文件中的设备信息进行统计计算输出统计结果返回主菜单 程序void Tongji(Node *equip)/统计Node *p;int sel;int flag2=0,ha=0;p=equip->next;char find20; if(!equip->next) /若链表为空 printf("n>>>>>>>>>>提示:没有资料可以统计分类!n"); return;printf(">>>>>>>

17、>>>提示:n=>0退出n=>1按设备号统计n=>2按设备名称统计n");scanf("%d",&sel);if(sel=1) printf("n输入你要统计分类的设备号:");scanf("%s",find); while(p) if(strcmp(p->data.ID,find)=0) flag2+; if(flag2=1&&ha!=flag2) printf("设备号 设备名称 设备种类 报废日期 是否报废 购买时间 价格n"); p

18、rintf("n%-13s%-11s%-7s%-10s%-13s%-10s%-5sn",p->data.ID,p->,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price); ha=flag2; else if(flag2>ha)printf("n%-13s%-11s%-7s%-10s%-13s%-10s%-5sn",p->data.ID,p->,p->data.kind,p

19、->data.over,p->data.yesno,p->data.time,p->data.price);ha=flag2; p=p->next; if(flag2) printf("n*按设备号%s统计分类的有%d条记录:*nn",find,flag2); else printf("n按设备号%s统计的结果为0个nn",find);else if(sel=2) printf("n输入你要统计分类的设备名称:"); scanf("%s",find); while(p) if(strc

20、mp(p->,find)=0) flag2+; if(flag2=1&&ha!=flag2) printf("设备号 设备名称 设备种类 报废日期 是否报废 购买时间 价格n"); printf("n%-13s%-11s%-7s%-10s%-13s%-10s%-5sn",p->data.ID,p->,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price); ha=flag2;

21、else if(flag2>ha)printf("n%-13s%-11s%-7s%-10s%-13s%-10s%-5sn",p->data.ID,p->,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price);ha=flag2; p=p->next; if(flag2) printf("n*按设备名称%s统计的有%d条记录:*nn",find,flag2); else printf("n按设备名

22、称%s统计分类的结果为0个nn",find);else if(sel=0) return;(4)显示模块 需求分析 该模块的功能是查找用户需要的对应记录,可以分别根据设备编号、设备种类、设备名称、设备购入日期、正常设备(未报废的)等多种方式查询。 流程图询问用户想要选择的搜索方式 y设备编号设备种类设备名称设备购入日期是否报废yn显示找到的文件提示没有找到让用户选择1)返回主菜单2)跳出系统 程序 /*显示模块*/void Disp(Node *equip)/输出记录Node *p;p=equip->next;if(!p) printf("n>>>&

23、gt;>>>>>>提示:没有记录可以显示!n"); return; printf("tttt显示结果n"); printf("设备号 设备名称 设备种类 报废日期 是否报废 购买时间 价格n"); while(p) printf("n%-13s%-11s%-7s%-10s%-13s%-10s%-5sn",p->data.ID,p->,p->data.kind,p->data.over,p->data.yesno,p->data.time

24、,p->data.price); p=p->next;4、 设计体会及总结 经过一个星期的上机实践学习,使我对C语言有了更进一步的认识和了解,要想学好它要重在实践,要通过不断的上机操作才能更好地学习它,通过实践,我也发现我的好多不足之处,对C语言的一些标准库函数不太了解,还有对函数调用的正确使用不够熟悉,还有对C语言中经常出现的错误也不了解,通过实践,使我在这几个方面的认识有所提高。通过实践的学习,我认到学好计算机要重视实践操作,不仅仅是学习C语言,还是其它的语言,以及其它的计算机方面的知识都要重在实践,所以后在学习过程中,我会更加注视实践操作,使自己便好地学好计算机。参考文献:1

25、. 何钦铭,颜晖,C语言程序设计,高等教育出版社。2. C语言入门经典是2008年清华大学出版社出版的图书,作者是霍顿。3. C程序设计语言(第2版·新版)Brian WKernighan, Dennis MRitchie徐宝文 李志 译附录一: #include <stdio.h>#include <stdlib.h>#include <string.h>struct shebeichar ID10; char name15; char kind15; char over15; char yesno10; char time10; char pr

26、ice10; ;typedef struct nodestruct shebei data;struct node *next; /建立一个链表。Node;void Add(Node *equip) /添加记录Node *p,*r,*s; char id10; /先用于输入ID,也用于判断是否跳出循环r=equip;s=equip->next; /使s为第一个有用的结点while(r->next!=NULL) /这个循环的作用是使r为最后一个有用的结点r=r->next; /将指针置于最末尾while(1) printf(">>>>>&

27、gt;>>>>提示:输入0则返回主菜单!n"); printf("n请你输入设备ID号:"); scanf("%s",id); if(strcmp(id,"0")=0) break; p=(Node *)malloc(sizeof(Node); /申请空间 strcpy(p->data.ID,id); printf("n请输入设备名称:"); scanf("%s",p->); printf("n请输入设备种类:"

28、); scanf("%s",p->data.kind); printf("n请输入报废日期:"); scanf("%s",&p->data.over); printf("n请输入设备是否报废:"); scanf("%s",&p->data.yesno); printf("n请输入设备购买时间:"); scanf("%s",&p->data.time); printf("n请输入设备价格:"

29、); scanf("%s",&p->data.price); printf(">>>>>>>>>>提示:已经完成一条记录的添加。n"); p->next=NULL; r->next=p; /这一步是必需的,将p与先前的链表连起来构成一条新链表 r=p; /也是必需的.将r 又重设为新链的最后一个有用结点 void Modify(Node *equip)/修改Node *p;char find20;if(!equip->next) printf("n>

30、;>>>>>>>>>提示:没有资料可以修改!n"); return;printf("请输入要修改的设备ID号:"); scanf("%s",find); p=equip->next; while(p!=NULL) if(strcmp(p->data.ID,find)=0) /如果找到的话返回的是符合要求 break; p=p->next; if(p) /若找到 int x; while(1) printf("完成修改请输入0否则输入任意数再进行修改:")

31、; scanf("%d",&x); if(x=0) break; printf("请输入新设备号(原来是 %s ):",p->data.ID); scanf("%s",p->data.ID); printf("请输入新设备名称(原来是 %s ):",p->); scanf("%s",p->); printf("请输入新设备设备种类名称(原来是 %s ):",p->data.kind); scanf(&q

32、uot;%s",p->data.kind); printf("请输入新设备报废日期名称(原来是 %s ):",p->data.over); scanf("%s",p->data.over); printf("请输入新设备是否报废(原来是 %s ):",p->data.yesno); scanf("%s",p->data.yesno); printf("请输入新设备购买时间(原来是 %s ):",p->data.kind); scanf("%

33、s",p->data.time); printf("请输入新设备价格(原来是 %s ):",p->data.price); scanf("%s",p->data.price); printf("n>>>>>>>>>>提示:该项记录资料已经成功修改!n"); else printf("n>>>>>>>>>>提示:你要修改的信息不存在!n"); void Disp(Node

34、 *equip)/输出记录Node *p;p=equip->next;if(!p) printf("n>>>>>>>>>>提示:没有记录可以显示!n"); return; printf("tttt显示结果n"); printf("设备号 设备名称 设备种类 报废日期 是否报废 购买时间 价格n"); while(p) printf("n%-13s%-11s%-7s%-10s%-13s%-10s%-5sn",p->data.ID,p->da

35、,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price); p=p->next;void Tongji(Node *equip)/统计Node *p;int sel;int flag2=0,ha=0;p=equip->next;char find20; if(!equip->next) /若链表为空 printf("n>>>>>>>>>>提示:没有资料可以统计分类!n");

36、return;printf(">>>>>>>>>>提示:n=>0退出n=>1按设备号统计n=>2按设备名称统计n");scanf("%d",&sel);if(sel=1) printf("n输入你要统计分类的设备号:");scanf("%s",find); while(p) if(strcmp(p->data.ID,find)=0) flag2+; if(flag2=1&&ha!=flag2) printf(

37、"设备号 设备名称 设备种类 报废日期 是否报废 购买时间 价格n"); printf("n%-13s%-11s%-7s%-10s%-13s%-10s%-5sn",p->data.ID,p->,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price); ha=flag2; else if(flag2>ha)printf("n%-13s%-11s%-7s%-10s%-13s%-10s%-5sn"

38、,p->data.ID,p->,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price);ha=flag2; p=p->next; if(flag2) printf("n*按设备号%s统计分类的有%d条记录:*nn",find,flag2); else printf("n按设备号%s统计的结果为0个nn",find);else if(sel=2) printf("n输入你要统计分类的设备名称:"

39、;); scanf("%s",find); while(p) if(strcmp(p->,find)=0) flag2+; if(flag2=1&&ha!=flag2) printf("设备号 设备名称 设备种类 报废日期 是否报废 购买时间 价格n"); printf("n%-13s%-11s%-7s%-10s%-13s%-10s%-5sn",p->data.ID,p->,p->data.kind,p->data.over,p->data.yesno,p->data.time

温馨提示

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

评论

0/150

提交评论