C语言课程设计商场商品信息管理系统报告论文.doc

上传人:laozhun 文档编号:2384797 上传时间:2023-02-17 格式:DOC 页数:21 大小:150KB
返回 下载 相关 举报
C语言课程设计商场商品信息管理系统报告论文.doc_第1页
第1页 / 共21页
C语言课程设计商场商品信息管理系统报告论文.doc_第2页
第2页 / 共21页
C语言课程设计商场商品信息管理系统报告论文.doc_第3页
第3页 / 共21页
C语言课程设计商场商品信息管理系统报告论文.doc_第4页
第4页 / 共21页
C语言课程设计商场商品信息管理系统报告论文.doc_第5页
第5页 / 共21页
点击查看更多>>
资源描述

《C语言课程设计商场商品信息管理系统报告论文.doc》由会员分享,可在线阅读,更多相关《C语言课程设计商场商品信息管理系统报告论文.doc(21页珍藏版)》请在三一办公上搜索。

1、摘要 C语言程序的发展与应用为各个方面均带来了较多的便捷,更为便捷的实现了数据的快捷运算和对数据的处理与应用,而本文主要介绍了商场商品信息管理系统,该程序有非常多的优点和便捷之处,为商场提供了很大的便利。 系统商场商品信息管理系统较好的运用到了商品管理系统中,运用数据管理系统较全面的实现了对商品的各种信息的处理运用,通过C语言程序中队各种 函数的运用对商品信息的处理和存储,完成了对商品信息的输入,以及对商品信息数据的处理,如对商品信息的排序,通过各种函数按照商品的编号和种类等方面对其进行排序,对商品新进货量与销售量的存储,处理和更新,以及向管理系统输入添加和删除商品信息,修改以及查询和处理商品

2、信息,还实现了对商品信息的总计统计,较为系统全面的对商品信息的各种处理,运用和更新,以及最后以文件形式完成了对信息的存储以及再次利用。关键字:C语言;商场商品信息管理系统;信息处理课程设计(论文)任务书学 院理学院专 业信息显示与光电技术学 生 姓 名王晗学 号1109040132课程设计(论文)题目商场商品信息管理系统设计要求(技术参数):进一步培养学生结构化程序设计的思想,加深对高级语言基本语言要素和控制结构的理解;针对C语言中的重点和难点内容进行训练,独立完成有一定工作量的程序设计任务,同时强调好的程序设计风格。设计任务:商场商品信息管理系统实现了多种功能的对商品信息的处理和存储,实现了

3、对商品信息的输入,按照号码和名称种类对商品排序,新进货量与销售量的存储更新,添加和删除商品,修改以及查询和处理信息,最后对信息的处理和保存,比较全面的实现了商品信息的处理。进度安排:第一周 查阅资料 第二周 第一、二天 程序设计 ;第三、四天 程序调试与测试 ;第五天 答辩 成绩:指导教师(签字):年 月 日专业负责人(签字):年 月 日学院院长(签字):年 月 日目 录1 系统分析21.1 课程设计内容21.2 系统功能需求分析21.3 数据结构设计32 系统设计32.1 总体设计32.2 详细设计42.2.1 界面设计42.2.2 各功能模块的设计63 系统编码设计93.1 main函数9

4、4 系统运行225 总结261 系统分析1.1 课程设计内容商场商品信息管理系统1.2 系统功能需求分析本系统应具有以下功能:1、 文件操作功能 文件操作:可建立、打开、保存、关闭数据文件。如果是新建的文件,可输入商品信息数据:数据包括商品编号、商品名、商品类别、商品数量、商品价格等。2、数据输入功能输入进货信息:输入商品编号、数量完成进货操作。输入销售信息:输入商品编号、数量完成销售操作,注意当销售数量大于商品数量时,应出现错误提示。3、 数据添加、修改、删除功能添加:添加一种或多种新商品,并能输入其商品信息。修改:修改商品信息,可包括商品编号、名称、种类、数量和单价。删除:删除一类或多类商

5、品的所有信息。4、 计算功能 可通过查询商品信息功能,自动计算并输出需要进货的商品信息。5、 查询功能 可分别按商品编号、名称、类别和需要进货的商品进行查询。6、 排序功能 可分别按商品编号、名称、类别等进行排序。1.3 数据结构设计struct goods /*商品结构体*/ long int num; /*商品编号*/ char name20; /*商品名称*/ char sort20; /*商品类别*/ long int count; /*商品库存量*/ long int price; /*商品单价*/ goods200; /*最多200个商品*/2 系统设计2.1 总体设计按系统分析的

6、功能要求将系统划分为以下几个主要功能模块:一、 文件管理n 文件打开、关闭:对于刚输入或进行操作后的商品信息,在建立新的商品库存量后,可以把其保存在一个文件中,并对该文件可进行打开和关闭操作。二、 进出货管理n 商品进货: 输入数据后商品信息能自动更新进行添加n 商品销售: 输入数据后商品信息能自动更新进行减少三、商品数据管理n 增加/删除商品: 添加或删除某条商品的信息n 修改商品信息: 对某条商品的信息进行修改四、浏览商品信息管理n 查询商品信息:可分别按商品编号、名称、类别或需要进货商品查询n 排序商品信息: 可按商品编号、名称、类别分别排排序2.2 详细设计2.2.1 界面设计1、 菜

7、单设计n 欢迎界面:n 系统提示:n 菜单设计:2、 输入界面的设计3、 信息显示界面的设计2.2.2 各功能模块的设计根据划分的功能模块,定义以下函数实现各功能:(这部分应介绍各函数的原型,各功能模块实现所用的算法,可用流程图描述)1、 主函数main()定义主函数为空类型(void);利用选择结构(switch)实现在在主函数中的调用各个子函数,利用goto 和子函数中的return语句实现返回主菜单的循环。声明各个子函数输出欢迎界面输出菜单switch(m)1输入商品信息2排序商品信息3输入商品进货信息4输入商品销售信息5增加/删除商品6修改商品信息7查询商品信息8保存商品信息清屏幕2、

8、 子函数(1) void input():确定新的库存量n,输入商品信息,用for循环语句直到输入商品种类等于n,结束输入;(2) void sequence():对已有的商品进行排序,可按商品编号、名称、类别进行排序;(3) void purchase():进货函数主要是针对已有库存的商品,在原来的商品数量再增加:(4) void sale():要求用户输入所销售的编号,系统用for 循环查询该商品是否存在,不存在要求再进行输入,直到输入正确,输出销售商品:(5) void edit():因为在进货函数已经实现对已有商品的数量的增加,此模块函数主要实现对新商品的添加或对旧商品的删除,并自动处

9、理数据,可以在浏览中输出,用选择语句switch进行俩者操作的选择:(6) void correct():对有错误信息商品进行修改,输入需要修改的商品编号,用for 循环与if语句找到此商品,重新输入该商品的新信息,并输出:(7) void search():用switch(k)语句可分别按商品编号、名称、类别或需要进货商品查询;每个case选择中均用for语句查找要查询的商品,并输出查询结果。(8) void reserve():建立文件FILE *fp;char file15用来存放文件保存路径以及文件名,进行清屏,输入文件路径及文件名,利用fp=fopen(file,w+)实现创建并打开

10、一个文件,并得到该文件的地址的功能,显示fprintf(fp,商品编号t商品名 t商品类别t商品数量t商品价格n); 最后输出已保存文件,程序中是由PR(商品编号t商品名 t商品类别t商品数量t商品价格n);语句执行。3 系统编码设计(这部分将代码列出,注意,每个函数开始处要介绍函数的功能,重要的代码应有注释,代码格式按锯齿式编排)3.1 main函数#include stdio.h#include string.h#include stdlib.h#define PR printf#define SC scanf struct goods long int num; char name20;

11、 char sort20; long int count; long int price; goods200; int k,n,i; void main () void input();void sequence();void purchase(); void sell(); void edit(); void correct(); void search(); void reserve(); void exit(); PR(n *n *tttttttt *n);PR( * *);PR(n *tttttttt *n * Welcometttttt *n *tttttttt *n);PR( *t

12、t to go into .tttt * );PR(n *tttttttt *n);PR( * -the Goods Information Manageaent System- *n *tttttttt *n );PR( * *n);PR( *tttttttt *n *);PR(nntPlease press any key to continue:);getch(); system(cls);PR( -$-$-$-$-$-$-$-$-$-);PR( nplease press any key to continue);getch();system(cls); lp: for(i=0;i1;

13、i+) PR(nnn); PR(nttt the Goods Information Manageaent system tnn); PR(t 1 input goods informationnn); PR(t 2 paixu goods information nn); PR(t 3 input jinhuo informationtt6 xiugai goods informationnn); PR(t 4 input sell informationtt7 chaxun goods informationnn); PR(t 5 zengjia/shanchu goodstt8 baoc

14、un goods informationnn); PR( tt ); PR(nn); PR(t qing xuanze chaozuo(xuan (0) tuichu):); SC(%d,&k); system(cls); switch(k) case 1: input();break; case 2: sequence();break; case 3: purchase();break; case 4: sell();break; case 5: edit();break; case 6: correct();break; case 7: search();break; case 8: re

15、serve();break; case 0: PR(nnt / / / / / _ nntThangyou,Welcome again,ByeByeO(_)O);exit(0); default: puts(shuru cuowu, qing fanhui zhucaidan :n); break; system(cls); goto lp; void input() PR(n qing shuru xuyao jianli xinkucun de shangpin zhonglei shuliang:); SC(%d,&n); system(cls); PR(n n); for(i=0;in

16、;i+) PR(nt*input goods.num:); SC(%ld,&goodsi.num); PR(nt input goods.name:); SC(%s,goodsi.name); PR(nt input goods.sort:); SC(%s,goodsi.sort); PR(nt input goods.count:); SC(%d,&goodsi.count); PR(nt input goods.price:); SC(%d,&goodsi.price); PR(n n); PR(tPlease press any key to continue:); getch(); r

17、eturn; void sequence() long temp; char p130,p230; for(k=0;kn-1;k+) for(i=0;igoodsi+1.num) temp=goodsi.num; goodsi.num=goodsi+1.num; goodsi+1.num=temp; strcpy(p1,goodsi.name); strcpy(goodsi.name,goodsi+1.name); strcpy(goodsi+1.name,p1); strcpy(p2,goodsi.sort); strcpy(goodsi.sort,goodsi+1.sort); strcp

18、y(goodsi+1.sort,p2); PR(-); PR(ntt anzhao bianhao paixu de shangpin xinxi nn); PR(tnum name sort count pricen); for(i=0;in;i+) PR(t %5ld %5s %5s %5ld %5ldn,goodsi.num,goodsi.name,goodsi.sort,goodsi.count,goodsi.price); for(k=0;kn-1;k+) for(i=0;i0) strcpy(p1,goodsi.name); strcpy(goodsi.name,goodsi+1.

19、name); strcpy(goodsi+1.name,p1); temp=goodsi.num; goodsi.num=goodsi+1.num; goodsi+1.num=temp; strcpy(p2,goodsi.sort); strcpy(goodsi.sort,goodsi+1.sort); strcpy(goodsi+1.sort,p2); PR(-); PR(nttanzhao mingzhi paixude xinxin); PR(ntnum name sort count pricen); for(i=0;in;i+) PR(t %5s %5ld %5s %5ld %5ld

20、n,goodsi.name,goodsi.num,goodsi.sort,goodsi.count,goodsi.price); for(k=0;kn-1;k+) for(i=0;i0) strcpy(p2,goodsi.sort); strcpy(goodsi.sort,goodsi+1.sort); strcpy(goodsi+1.sort,p2); temp=goodsi.num; goodsi.num=goodsi+1.num; goodsi+1.num=temp; strcpy(p1,goodsi.name); strcpy(goodsi.name,goodsi+1.name); s

21、trcpy(goodsi+1.name,p1); PR(-); PR(nttanzhao leibie paixude xinxinn); PR(tnum name sort count pricen); for(i=0;in;i+) PR(t %5s %5ld %5s %5ld %5ldn,goodsi.sort,goodsi.num,goodsi.name,goodsi.count,goodsi.price); PR(-); PR(please press any key to continue:); getch(); return; void purchase() long temp;

22、int j; PR(nt5input new goods.num:); SC(%ld,&temp); PR(nt5input new goods.count:); SC(%d,&j); PR(nnntpress any key to contiue:); getch(); system(cls); PR(ntshuchu jinhuohoude shangpin xinxi :); for(i=0;in;i+) if(temp=goodsi.num) goodsi.count=goodsi.count+j; PR(ntnum name sort count price); for(i=0;in

23、;i+) PR(nt %4ld %4s %4s %ld %4ld,goodsi.num,goodsi.name,goodsi.sort,goodsi.count,goodsi.price); PR(nnttPress any key to enter menu:); getch(); return; void sell() long temp; int j; PR(nt5input sell goods.num:); SC(%ld,&temp); PR(nt5input sell goods.count:); SC(%d,&j); for(i=0;igoodsi.count;) PR(ntsh

24、ouchu shuliang dayu yuanyou shuliang ,cuowu,qing chongxin shuru:); SC(%d,&j); goodsi.count=goodsi.count-j; PR(ntpress any key to contiue:); getch(); system(cls); PR(nn *xiaoshou houde shangpin xinxi:); PR(ntsort num name count pricen); for(i=0;in;i+) PR(t %4s %4ld %4s %4ld %4ldn,goodsi.sort,goodsi.n

25、um,goodsi.name,goodsi.count,goodsi.price); PR(ntPress any key to enter menu:); getch(); return; void edit() void add();void dele();PR(ntxuanze:1.add goods; 2.dele doods;);PR(t*input 1 or 2 go on :);SC(%d,&k);switch(k) case 1: add();break; case 2: dele();break; getch(); return; void add() PR(t*input

26、add goods.num:); SC(%ld,&goodsn.num); PR(ntinput add goods.name:); SC(%s,goodsn.name); PR(ntinput add goods.sort:); SC(%s,goodsn.sort); PR(ntinput add goods.count:); SC(%d,&goodsn.count); PR(ntinput add goods.price:); SC(%d,&goodsn.price); n=n+1; PR(n); void dele() int temp; int j; for(i=0;in;i+) PR

27、(ntnum name sort count price); PR(nt %5ld %5s %5s %5ld %5ld,goodsi.num,goodsi.name,goodsi.sort,goodsi.count,goodsi.price); PR(n); PR(n); PR(n*input dele goods.num:); SC(%ld,&temp); PR(nn); for(i=0;in;i+) if(temp=goodsi.num) for(j=i;jn;j+) goodsj.num=goodsj+1.num; strcpy(goodsj.name,goodsj+1.name); s

28、trcpy(goodsj.sort,goodsj+1.sort); goodsj.count=goodsj+1.count; goodsj.price=goodsj+1.price; n=n-1; for(i=0;in;i+) PR(ntnum name sort count price); PR(nt %5ld %5s %5s %5ld %5ld,goodsi.num,goodsi.name,goodsi.sort,goodsi.count,goodsi.price); PR(n); PR(Please press any key to continue:); getch(); return

29、; void correct() long temp;PR(ntshuru xiugaide goods.num:);SC(%ld,&temp);PR(n);for(i=0;in;i+) if(temp=goodsi.num) PR(tinput new goods.num:); SC(%ld,&goodsi.num); PR(ntinput new goods.name:); SC(%s,goodsi.name); PR(ntinput new goods.sort:); SC(%s,goodsi.sort); PR(ntinput new goods.count:); SC(%d,&goo

30、dsi.count); PR(ntinput new goods.price:); SC(%d,&goodsi.price); PR(n); for(i=0;in;i+) PR(ntnew name num sort count pricen); PR(t %4s %4ld %4s %4ld %4ld,goodsi.name,goodsi.num,goodsi.sort,goodsi.count,goodsi.price); PR(n); PR(Please press any key to continue:); getch(); return; void search() int k; l

31、ong temp1; char temp230,temp320; PR(nt5search goods.num,xuan 1ttt5search goods.name, xuan 2nt5search goods.sort,xuan 3ttt5search xuyao jinhuode goods,xuan 4n); PR(nnntttqing shuru shuzi chaxu:); SC(%d,&k); PR(n); PR(Press any key to continue:); getch(); system(cls); switch(k) case 1: PR(nnnnnttinput

32、 search goods.num:); SC(%ld,&temp1); system(cls); for(i=0;in;i+) if(temp1=goodsi.num) PR(n); PR(ntnum name sort count price); PR(nt %5ld %5s %5s %5ld %5ld,goodsi.num,goodsi.name,goodsi.sort,goodsi.count,goodsi.price); break; case 2: PR(nnnnnttinput search goods.name:); SC(%s,temp2); system(cls); for(i=0;in;i+) if(strcmp(temp2,goodsi.name)=0) PR(n); PR(ntnum name sort count price); PR(nt %5ld %5s %5s %5ld %5ld,goodsi.num,goodsi.name,goodsi.sort,goodsi.count,goodsi.price); break; case 3: PR(nnnnnttinput search goods.sort:); SC(%s,temp3); system(cls); for(i=0;in;i+)

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 建筑/施工/环境 > 项目建议


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号