实验室设备管理系统方案.docx
《实验室设备管理系统方案.docx》由会员分享,可在线阅读,更多相关《实验室设备管理系统方案.docx(26页珍藏版)》请在冰豆网上搜索。
实验室设备管理系统方案
宁波工程学院
2015~2016学年第二学期
电信学院
C语言课程设计报告
题目:
实验室设备管理系统
班级:
计科152
姓名:
孔庆康
学号:
指导教师:
洪立
2016年6月
1、系统功能和结构
1.1系统设计目的\
因为现在各个高校教学设备众多但自动管理水平相比过低,很多高校管理设备都采用在设备购进以后将设备的根本情况和相关信息登记存档。
存档以后档案根本就没人记录与维护,至于以后设备的变迁或损坏都不会记录在设备档案中,即不能表达设备的即时状态。
而有些即使有设备管理系统的单位,就算是能把设备的即时信息表达在设备档案上,但设备的缺陷处理与设备缺陷等功能没有实施,设备检修的备品备件情况和检修本钱核算没有实现,整个学校教学设备管理信息化仍处于较低水平。
将管理任务分成小块,落实到个人并能随时查询设备当前情况和历史情况,对设备的可靠性分析有直接作用,使管理人员从手工计算、统计工作中解脱出来。
1.2系统功能分析
实验室设备信息用文件存储,提供文件的输入输出操作;要能够完成设备的录入和修改,需要提供设备添加和修改操作;实现对设备进展分类统计,需要提供排序操作;实现对设备的插叙需要提供查找操作,设备的查询可根据设备编号、设备种类、设备名称、设备购入日期、正常设备〔未报废的〕等多种方式查询;另外还要提供键盘式选择菜单以实现功能选择。
1.3系统结构分析
根据上面的需求分析,可以将这个系统的设计分为以下模块
2、核心技术介绍
主函数
[流程图]
[程序]
voidmain()
{
Node*equip;
FILE*fp;
intflag;
Node*p,*q;
printf("\t\t\t\t设备管理系统\n");
equip=(Node*)malloc(sizeof(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("\n2修改记录\n");
printf("\n3显示记录\n");
printf("\n4统计分类记录\n");
printf("\n0*-EXIT-*\n");
printf("请输入你要操作的序号:
");
scanf("%d",&flag);
switch(flag)
{
case0:
printf("\n>>>>>>>>>>提示:
已经退出系统,ByeBye!
\n");break;
case1:
Add(equip);break;//增加记录
case2:
Modify(equip);break;//修改记录
case3:
Disp(equip);break;//显示记录信息
case4:
Tongji(equip);break;//统计记录
default:
printf("\n>>>>>>>>>>提示:
输入错误!
\n");break;
}
}
}
3、函数功能介绍
〔1〕输入模块
[流程图]
[程序]
/***************************输入模块*****************************/
#include"stdio.h"
#include"stdlib.h"
#include"string.h"
structshebei
{
charID[10];
charname[15];
charkind[15];
charover[15];
charyesno[10];
chartime[10];
charprice[10];
};
typedefstructnode
{
structshebeidata;
structnode*next;//建立一个链表。
}Node;
voidAdd(Node*equip)//添加记录
{
Node*p,*r,*s;
charid[10];//先用于输入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)break;
p=(Node*)malloc(sizeof(Node));//申请空间
strcpy(p->data.ID,id);
printf("\n请输入设备名称:
");
scanf("%s",p->data.name);
printf("\n请输入设备种类:
");
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请输入设备价格:
");
scanf("%s",&p->data.price);
printf(">>>>>>>>>>提示:
已经完成一条记录的添加。
\n");
p->next=NULL;
r->next=p;//这一步是必需的,将p与先前的链表连起来构成一条新链表
r=p;//也是必需的.将r又重设为新链的最后一个有用结点
}
}
〔2〕修改模块
[需求分析]
此模块可以根据客户需要对以记录在文件中的信息进展修改
[流程图]
[程序]
/***************************修改模块*****************************/
voidModify(Node*equip)//修改
{
Node*p;
charfind[20];
if(!
equip->next)
{
printf("\n>>>>>>>>>>提示:
没有资料可以修改!
\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)//假设找到
{
intx;
while
(1)
{
printf("完成修改请输入0否那么输入任意数再进展修改:
");
scanf("%d",&x);
if(x==0)
{break;}
printf("请输入新设备号(原来是%s):
",p->data.ID);
scanf("%s",p->data.ID);
printf("请输入新设备名称(原来是%s):
",p->data.name);
scanf("%s",p->data.name);
printf("请输入新设备设备种类名称(原来是%s):
",p->data.kind);
scanf("%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.time);
scanf("%s",p->data.time);
printf("请输入新设备价格(原来是%s):
",p->data.price);
scanf("%s",p->data.price);
printf("\n>>>>>>>>>>提示:
该项记录资料已经成功修改!
\n");
}
}
elseprintf("\n>>>>>>>>>>提示:
你要修改的信息不存在!
\n");
}
〔3〕统计模块
[需求分析]
将已经输入的设备信息进展统计,并显示设备总数、价格总额等信息
[流程图]
[程序]
voidTongji(Node*equip)//统计
{
Node*p;
intsel;intflag2=0,ha=0;
p=equip->next;
charfind[20];
if(!
equip->next)//假设链表为空
{
printf("\n>>>>>>>>>>提示:
没有资料可以统计分类!
\n");
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("设备号设备名称设备种类报废日期是否报废购置时间价格\n");
printf("\n%-13s%-11s%-7s%-10s%-13s%-10s%-5s\n",p->data.ID,p->data.name,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price);
ha=flag2;
}
elseif(flag2>ha){printf("\n%-13s%-11s%-7s%-10s%-13s%-10s%-5s\n",p->data.ID,p->data.name,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条记录:
*************************\n\n",find,flag2);
}
else{printf("\n按设备号%s统计的结果为0个\n\n",find);}
}
elseif(sel==2)
{
printf("\n输入你要统计分类的设备名称:
");
scanf("%s",find);
while(p)
{
if(strcmp(p->data.name,find)==0)
{
flag2++;
}
if(flag2==1&&ha!
=flag2)
{printf("设备号设备名称设备种类报废日期是否报废购置时间价格\n");
printf(
"\n%-13s%-11s%-7s%-10s%-13s%-10s%-5s\n",p->data.ID,p->data.name,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price);
ha=flag2;
}
elseif(flag2>ha){printf(
"\n%-13s%-11s%-7s%-10s%-13s%-10s%-5s\n",p->data.ID,p->data.name,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条记录:
********************\n\n",find,flag2);
}
else{printf("\n按设备名称%s统计分类的结果为0个\n\n",find);}
}
elseif(sel==0)return;
}
(4)显示模块
[需求分析]
该模块的功能是查找用户需要的对应记录,可以分别根据设备编号、设备种类、设备名称、设备购入日期、正常设备〔未报废的〕等多种方式查询。
[流程图]
y
[程序]
/*******************************显示模块******************************/
voidDisp(Node*equip)//输出记录
{
Node*p;
p=equip->next;
if(!
p)
{
printf("\n>>>>>>>>>>提示:
没有记录可以显示!
\n");
return;
}
printf("\t\t\t\t显示结果\n");
printf("设备号设备名称设备种类报废日期是否报废购置时间价格\n");
while(p)
{
printf("\n%-13s%-11s%-7s%-10s%-13s%-10s%-5s\n",p->data.ID,p->data.name,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price);
p=p->next;
}
}
4、设计体会与总结
经过一个星期的上机实践学习,使我对C语言有了更进一步的认识和了解,要想学好它要重在实践,要通过不断的上机操作才能更好地学习它,通过实践,我也发现我的好多缺乏之处,对C语言的一些标准库函数不太了解,还有对函数调用的正确使用不够熟悉,还有对C语言中经常出现的错误也不了解,通过实践,使我在这几个方面的认识有所提高。
通过实践的学习,我认到学好计算机要重视实践操作,不仅仅是学习C语言,还是其它的语言,以与其它的计算机方面的知识都要重在实践,所以后在学习过程中,我会更加注视实践操作,使自己便好地学好计算机。
参考文献:
1.何钦铭,颜晖,C语言程序设计,高等教育。
2.《C语言入门经典》是2008年清华大学出版的图书,作者是霍顿。
3.C程序设计语言〔第2版·新版〕BrianW.Kernighan,DennisM.Ritchie徐宝文志译
附录一:
#include
#include
#include
structshebei
{
charID[10];
charname[15];
charkind[15];
charover[15];
charyesno[10];
chartime[10];
charprice[10];
};
typedefstructnode
{
structshebeidata;
structnode*next;//建立一个链表。
}Node;
voidAdd(Node*equip)//添加记录
{
Node*p,*r,*s;
charid[10];//先用于输入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)break;
p=(Node*)malloc(sizeof(Node));//申请空间
strcpy(p->data.ID,id);
printf("\n请输入设备名称:
");
scanf("%s",p->data.name);
printf("\n请输入设备种类:
");
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请输入设备价格:
");
scanf("%s",&p->data.price);
printf(">>>>>>>>>>提示:
已经完成一条记录的添加。
\n");
p->next=NULL;
r->next=p;//这一步是必需的,将p与先前的链表连起来构成一条新链表
r=p;//也是必需的.将r又重设为新链的最后一个有用结点
}
}
voidModify(Node*equip)//修改
{
Node*p;
charfind[20];
if(!
equip->next)
{
printf("\n>>>>>>>>>>提示:
没有资料可以修改!
\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)//假设找到
{
intx;
while
(1)
{
printf("完成修改请输入0否那么输入任意数再进展修改:
");
scanf("%d",&x);
if(x==0)
{break;}
printf("请输入新设备号(原来是%s):
",p->data.ID);
scanf("%s",p->data.ID);
printf("请输入新设备名称(原来是%s):
",p->data.name);
scanf("%s",p->data.name);
printf("请输入新设备设备种类名称(原来是%s):
",p->data.kind);
scanf("%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("%s",p->data.time);
printf("请输入新设备价格(原来是%s):
",p->data.price);
scanf("%s",p->data.price);
printf("\n>>>>>>>>>>提示:
该项记录资料已经成功修改!
\n");
}
}
elseprintf("\n>>>>>>>>>>提示:
你要修改的信息不存在!
\n");
}
voidDisp(Node*equip)//输出记录
{
Node*p;
p=equip->next;
if(!
p)
{
printf("\n>>>>>>>>>>提示:
没有记录可以显示!
\n");
return;
}
printf("\t\t\t\t显示结果\n");
printf("设备号设备名称设备种类报废日期是否报废购置时间价格\n");
while(p)
{
printf("\n%-13s%-11s%-7s%-10s%-13s%-10s%-5s\n",p->data.ID,p->data.name,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price);
p=p->next;
}
}
voidTongji(Node*equip)//统计
{
Node*p;
intsel;intflag2=0,ha=0;
p=equip->next;
charfind[20];
if(!
equip->next)//假设链表为空
{
printf("\n>>>>>>>>>>提示:
没有资料可以统计分类!
\n");
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("设备号设备名称设备种类报废日期是否报废购置时间价格\n");
printf("\n%-13s%-11s%-7s%-10s%-13s%-10s%-5s\n",p->data.ID,p->data.name,p->data.kind,p->data.over,p->data.yesno,p->data.time,p->data.price);
ha=flag2;