《C语言程序设计_销售管理系统.doc》由会员分享,可在线阅读,更多相关《C语言程序设计_销售管理系统.doc(32页珍藏版)》请在得力文库 - 分享文档赚钱的网站上搜索。
1、 C语言程序设计 销售信息管理系统设计文档 组号:第二组 成员:汪品高 齐瑞智 欧阳鑫 赵飞锋 章森 目录一 题目与要求二 功能实现设计(模块化设计)三 运行结果(附带抓图)四 源程序 报告正文1、 题目与要求:2、 某公司有四个销售员(编号:1-4),负责销售五种产品(编号:1-5)。每个销售员汇总当天出售的每种产品的销售情况。2 每天销售情况包括(销售员的代号、产品的代号、这种产品当天的销售额)1、 编写一个销售信息管理系统,读取上个月的销售情况1、 计算上个月没人每种产品的销售额2、 按销售额对销售员进行排序,输出排序结果(销售员代号)3、 统计每种产品的总销售额,对这些产品从高到低的顺
2、序输出结果(须输出产品的代号和销售额)4、 输出统计报表2、需求分析 本程序将用到文件系统E:/54321.doc文件内容作为数据源,其中单行内容代表一张纸条。程序运行后首先将文件系统的原始数据读取并保存到程序的结构体数组当中,所以应提供文件输入的操作;由于纸条数据零散,所以要对原始数据进行分类操作并提供一个数组用于保存分类信息;在程序中要进行统计工作,所以要提供显示、排序等操作;另外应提供键盘式选择菜单实现功能选择。3、功能实现设计3.1总体设计根据上面的分析,可以将这个系统分为如下五大模块:查看每人每种产品的销售额 、按销售额对销售员排序、对每种产品总销售额从高到低排序、输出统计报表和退出
3、。其中主要模块是前四个模块。开始3.2流程图推出系统读取便条上的信息3.3详细设计: 3.3.1【头文件和预定义】#include#include主菜单#include#include#define M3.3.2【功能函数声明】vvoid detail();void foreach();输出统计表统计总销售额并排序销售员销售业绩排序每个人每种产品销售额void menu();void product();void readdata();void seller();void total();选择void choice();退出系统返回主菜单3.3.3【数据结构】原始数据有销售员代号、产品代号和销
4、售额,所以定义一个全局结构体数组scrip用于保存原始数据。然后定义全局变量n保存纸条数目,定义数组s用于保存分类后的信息。struct ssint sid; /销售员代号int pid; /产品代号int sn; /销售额 ssM; int n; /纸条数目 int s45=0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0; /用于保存员工和产品信息3.3.4【主函数】显示程序设计者相关信息和调用文件读取函数、数据初始化函数和主菜单函数void main() /入口函数,即主函数readdata(); /读取文件数据foreach(); /根据文件初始数据初始化
5、便于操作的数组menu(); /显示主菜单3.3.4-1【文件读取函数】readdata()读出便条中的内容,并保存到文件结构体中void readdata() /从文件读取数据FILE *fp; /定义文件指针if(fp=fopen(list.txt,r)=NULL)printf(Cant open the file!n);exit(0);else for(n=0;!feof(fp);n+)fscanf(fp,%d %d %dn,&ssn.sid,&ssn.pid,&ssn.sn); /保存文件数据到结构体fclose(fp);3.3.4-2【文件读取函数】foreach()将保存到结构体中
6、的信息按产品分类,再根据销售员进行分类,将信息存到数组当中。 void foreach() /从纸条读取数据并分类整理int i;for(i=0;in;i+) /遍历所有纸条switch(ssi.pid) /按产品分大类(例如就是case1-5),根据大类分销售员小类,累加各人各产品销售数量 case 1: switch(ssi.sid) case 1:s00+=ssi.sn;break; case 2:s10+=ssi.sn;break; case 3:s20+=ssi.sn;break; case 4:s30+=ssi.sn;break; break; case 2: switch(ssi
7、.sid) case 1:s01+=ssi.sn;break; case 2:s11+=ssi.sn;break; case 3:s21+=ssi.sn;break; case 4:s31+=ssi.sn;break; break; case 3: switch(ssi.sid) case 1:s02+=ssi.sn;break; case 2:s12+=ssi.sn;break; case 3:s22+=ssi.sn;break; case 4:s32+=ssi.sn;break; break; case 4:switch(ssi.sid) case 1:s03+=ssi.sn;break;
8、 case 2:s13+=ssi.sn;break; case 3:s23+=ssi.sn;break; case 4:s33+=ssi.sn;break; break; case 5: switch(ssi.sid) case 1:s04+=ssi.sn;break; case 2:s14+=ssi.sn;break; case 3:s24+=ssi.sn;break; case 4:s34+=ssi.sn;break; ; break; 3.3.4-3【主菜单函数】menu()显示系统功能菜单以供用户选择相关功能使用,根据用户选择分别可调用detail():计算上个月每个人每种产品的销售额
9、seller():按销售额对销售员进行排序,输出排序结果(销售员代号)product():统计每种产品的总销售额,对这些产品按从高到低的顺序输出排序结果(需输出产品代号和销售额)exit(0):退出系统 void menu()int w,c;do puts(tt*菜单*nn); puts(tt 1.查看每人每种产品的销售额n); puts(tt 2.按销售额对销售员排序(销售员代号)n); puts(tt 3.对每种产品总销售额从高到低排序(产品代号和销售额)n); puts(tt 4.输出统计报表n); puts(tt 5.退出n); puts(nntt*n); printf(请选择(1-5
10、): bb); scanf(%d,&c); if(c5) /错误输入则重新获取输入 w=1 else w=0; while(w=1); switch(c) /根据输入实现相应函数调用 case 1: detail();break;/每个销售员每种产品的销售额统计 case 2: seller();break; case 3: product();break; case 4: total();break; case 5: exit(0); 3.3.5【功能函数】5-1【每人每种产品销售额统计函数】detail() 计算上个月每个人每种产品的销售额void detail() /显示销售情况int
11、i,j; for(i=0;i4;i+) /遍历销售员printf(ntt%d号销售员销售情况:n,i+1); for(j=0;j5;j+) /按销售员分类遍历所有产品并显示信息 printf(tt%d号产品销售数量:%dn,j+1,sij); choice();3.3.5-1【销售员销售业绩排序函数】seller()按销售额对销售员进行排序,输出排序结果(销售员代号)void seller()int i,j,k;int sp4=0,0,0,0;for(i=0;i4;i+)for(j=0;j5;j+)spi+=sij; /计算每单个销售员所有产品销售数量for(i=0;i4;i+) /比较四次,
12、每次选出最大数 k=0; /用于标记单轮最大数for(j=0;j4;j+)if(spkspj)k=j; /获取最大数标号printf(tt第%d名是%d号销售员!n,i+1,k+1);spk=-1; /输出最大数和排名,将最大数标记为负choice();3.3.5-2【总销售额统计函数】void product()统计每种产品的总销售额,对这些产品按从高到低的顺序输出排序 void product() /与seller()原理一样,用于对产品进行统计 int i,j,k;int p5=0,0,0,0,0;for(j=0;j5;j+)for(i=0;i4;i+)pj+=sij;for(j=0;j
13、5;j+) k=0;for(i=0;i5;i+)if(pkpi)k=i;printf(tt第%d名是%d号产品!t销量为%d!n,j+1,k+1,pk);pk=-1;choice();3.3.5-3【统计报表输出函数】total()统计每种产品的总销售额,对这些产品按从高到低的顺序输出排序结果(需输出产品代号和销售额)void total() /输出报表 int i,j;printf(nt销售员t产品t销量n);for(i=0;i4;i+)for(j=0;j返回菜单t2退出系统 bb);scanf(%d,&c);if(c=1)menu();elseexit(0);puts(n);4、运行结果(
14、附带抓图)List.txt(便条)文件中数据如下:(提前建立文件或就将便条保存在文件中! )1 1 11 2 21 3 31 4 81 5 92 1 32 2 32 3 42 4 52 5 63 1 13 2 1 (这是个例子)3 3 43 4 53 5 64 1 24 2 34 3 44 4 54 5 6运行结果 显示主菜单: 查看每人每种产品的销售额运行结果:按销售额对销售员按顺序排序(销售员代号)运行结果对每种产品销售额从高到低排序运行结果:统计报表运行结果:6、源程序#include #include#include /*调用exit函数*/#include#define M 155
15、/*宏定义*/void detail();void foreach();void menu();void product();void readdata();void seller();void total();void choice();struct ssint sid; /销售员代号int pid; /产品代号int sn; /销售额 ssM; int n; /纸条数目 int s45=0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0; /用于保存员工和产品信息void main() /入口函数,即主函数 p readdata(); /读取文件数据 forea
16、ch(); /根据文件初始数据初始化便于操作的数组 menu(); /显示主菜单void readdata() /从文件读取数据FILE *fp;if(fp=fopen(list.txt,r)=NULL)printf(Cant open the file!n);exit(0);else for(n=0;!feof(fp);n+)fscanf(fp,%d %d %dn,&ssn.sid,&ssn.pid,&ssn.sn); /保存文件数据到结构体fclose(fp); void foreach() /从纸条读取数据并分类整理int i;for(i=0;in;i+) /遍历所有纸条switch(s
17、si.pid) /按产品分大类,根据大类分销售员小类,累加个人各产品销售数量 case 1: switch(ssi.sid) case 1:s00+=ssi.sn;break; case 2:s10+=ssi.sn;break; case 3:s20+=ssi.sn;break; case 4:s30+=ssi.sn;break; break; case 2: switch(ssi.sid) case 1:s01+=ssi.sn;break; case 2:s11+=ssi.sn;break; case 3:s21+=ssi.sn;break; case 4:s31+=ssi.sn;break
18、; break; case 3: switch(ssi.sid) case 1:s02+=ssi.sn;break; case 2:s12+=ssi.sn;break; case 3:s22+=ssi.sn;break; case 4:s32+=ssi.sn;break; break; case 4:switch(ssi.sid) case 1:s03+=ssi.sn;break; case 2:s13+=ssi.sn;break; case 3:s23+=ssi.sn;break; case 4:s33+=ssi.sn;break; break; case 5: switch(ssi.sid
19、) case 1:s04+=ssi.sn;break; case 2:s14+=ssi.sn;break; case 3:s24+=ssi.sn;break; case 4:s34+=ssi.sn;break; ; break; void menu()int w,c;do puts(tt*菜单*nn); puts(tt 1.查看每人每种产品的销售额n); puts(tt 2.按销售额对销售员排序(销售员代号)n); puts(tt 3.对每种产品总销售额从高到低排序(产品代号和销售额)n); puts(tt 4.输出统计报表n); puts(tt 5.退出n); puts(nntt*n); p
20、rintf(请选择(1-5): bb); scanf(%d,&c); if(c5) /错误输入则重新获取输入 w=1; getchar(); else w=0; while(w=1); switch(c) /根据输入实现相应函数调用 case 1: detail();break;/每个销售员每种产品的销售额统计 case 2: seller();break; case 3: product();break; case 4: total();break; case 5: exit(0); void detail() /显示销售情况int i,j; for(i=0;i4;i+) /遍历销售员pri
21、ntf(ntt%d号销售员销售情况:n,i+1); for(j=0;j5;j+) /按销售员分类遍历所有产品并显示信息 printf(tt%d号产品销售数量:%dn,j+1,sij); choice();void seller()int i,j,k;int sp4=0,0,0,0;for(i=0;i4;i+)for(j=0;j5;j+)spi+=sij; /计算每单个销售员所有产品销售数量for(i=0;i4;i+) /比较四次,每次选出最大数 k=0; /用于标记单轮最大数for(j=0;j4;j+)if(spkspj)k=j; /获取最大数标号printf(tt第%d名是%d号销售员!n,
22、i+1,k+1);spk=-1; /输出最大数和排名,将最大数标记为负choice(); void product() /与seller()原理一样,用于对产品进行统计 int i,j,k;int p5=0,0,0,0,0;for(j=0;j5;j+)for(i=0;i4;i+)pj+=sij;for(j=0;j5;j+)k=0;for(i=0;i5;i+)if(pkpi)k=i;printf(tt第%d名是%d号产品!t销量为%d!n,j+1,k+1,pk);pk=-1;choice();void total() /输出报表 int i,j;printf(nt销售员t产品t销量n);for(
23、i=0;i4;i+)for(j=0;j返回菜单t2退出系统 bb);scanf(%d,&c);if(c=1)menu();elseexit(0);puts(n);32) ) ( ) ) =)& () 统 回返程什设来选( 选能信用/ )( ; + + % +0 +;0=)销产销 , 报出/ ) ; , ,!为 !号名第 ( + ( 00+0( + 0( +0(0, , 统进对用理) / ; 为标最,数出/ = + ,!号名% 标大获 + 0( 大轮记/ ; 大出每次比 + 0(数销有员个算/ + = +0 ,0, ( )( ) 数售 % 信显并历分销/ ) ; )+ :情售销( 售售/ ) ;
24、 情情/ ) )( ( ( 统售品每销/ ) 调函现输/ ) )= 0 ) 输获则误/ | )& ( ):(请 )* )退.( ) 表出输 ( )额和号序到高销产对 ) 号售序售额销 ( ) 售销种看 ) * ( ; =+ ;.=: . +: ; ; =: : ; + : . +0 ;. = =+ . 0: ( ;. . + ; = : . ; =0 : . 0: 0 数售品个类员销根大品按 ).( 纸所/ 0 整分并读/ ) ( 构构件保 ) & % % + )( 0( )( ) =). ( =( * 数读从 ) 菜示/ ( 数作操化始件/ ; 数文读 ; 函即函口 信产和保/,00,0,0
25、,0 数纸/ ; 售/ 代产 代员/ ) )( ) ) ) )( ) ) *义/ . *函 调 . 程果运果行排高售品结运号销序顺销额果行运品每:菜示 结 子例( !件存条或文提:据件便 .图带附行)()0 )( =),() 系出 回 么做接择 选功信输 ) 菜回则出( 数数函 ) ; , % % + ( +; )品产售 , 报输/ 额销代出(序输序到品这额售的( 】表计-) =) ,+ 量 产号是第 +0( 00 + ; = +0 +0( ,0= , 统进对,理( / ( 排输顺到品这对总产( 数计售 )( 为记大名数出/ - ; ,+ 售号名第 ( 标大最/ +;( 大轮标/ =大大每四比
26、 ) 数销产售个计/ + + 0( +0 ,0 , ( 号员(序输,行售( 数排售售销.)( ) + %数销 信示品所分销/ +; )+ 售员号 售历/ ) ;= 情销显 售的品人每) 函售产每【数能【 ) ( ( ( 统售品每员/ ; 调数现输/ ( ) ( 0 = 输取重误/ ) ) ) (择 ) * ( ) 出. ( ) 报出输( )额和品序到额销种. ) 号售(售对按 ( )额品产每. ) * ( 系退0(额销代出输序输的到按这对总产种: 号员售序输序进对销: 售销种每个上( 调可选用,能相户以能( 】函【- ; =+ : =: ;.= 0 =+ . : =+ ; = . =+: ;
27、. ;. =0 .= ; + =+ .=0: 0: ; =: .=0 ;. 00: . 数数产加累售分据 - 就如类品/ 纸所/ +0 整分数条/ ) 中中到信分进据,品按信构到( 取件-) 构到件存/) &.& & % ( +) 0( )( ) =) . = 指指/ ;* 数数文 ) 体结文并内的( 函件【 菜菜显 )数作便初据文/ ) 数文/ ; 函即函/ 函菜和化数数件调息相序数主.信产员保用,00,0000,00= 数纸/ 售/ 代代/ 代售销; 息信分保 数数存量局后据原存 体结一定额售品号员据构据【.菜系单主统选) ) ) ) ) & )() 售销种排 排排返排计)选 售种个序 单
28、菜据据品一 存后存 息 销代代 数=,0员主相件化菜 /即 文 文便数 菜函 (文 数*/指= = ) ( & /到- 信,分中 /整 + / 品就 分加 . ; 0. : : :0. + + . ; + =; = ; + 函(户能可(每销:序输 产这的输销0 * .品) 按售) 到序(输报 . * 择) ) )误取 )(/数 /品 ( 能每 )品售 情 售 +;+ /品 % )(.售 行,号(, ,+( + /售销 大 轮(+ 标(名 ,- 数大 数 产这顺输( 理进,0,0 + +0+ 第 量, - 的这序序销 /报 * . /*) ) ) / 售 数 ,0,产 口即 读文 /始数 菜 )
29、 读 = ) ) ( ) 构 分 纸 按根类品 0 0 . . . = . 0 :+ : : ; =; + * 种售 额序) 对销号 输表 ) *:) /获 =) 现 ) 品 ( ( / ;)/售(销售) /历 售 () + /个数( 比出大 /(0 大 %名 =,标 / 用 ,(+0+ (+( + 名 , ;) 出, 产0+0+ /能绩销销 排额计 明数能. 绩 )计排售 ) ) 排 额 菜 . . 义义文 :信 的条 条开程程块模前要主出表统输低额总产、员对售、售产人看模五分个将析的设总设设择能现单式供另作等示要,计进序在息保组数并操行数要所零纸;操件供以中体的序并读始的件首行条一容行其数容件 /系文用分求报计统额销代产须果序的从些对额品产号号销结输排行对售的品每个情销个读系息售额售天种这的号员售包情天况售品种售当员每):(产销负-号(个四求要正序图抓果计设模设要目 章章赵阳瑞高:成二第文计系 * 第高阳 要设果图四(销:员售况包员这额系销每售行销号额的须销统求系 件数一件读序以件纸所操保序,示作现设设将分看售售总输表前程的:文 32
限制150内