1、销售管理系统实用资料报告正文1、题目与要求:1.1某公司有四个销售员(编号:1-4),负责销售五种产品(编号:1-5)。每个销售员都将当日出售的每种产品各写一张便条交上来。每张便条内容有1、销售员的代号2、产品的代号3、这种产品当天的销售额1.2每位销售员每天可能上缴0-5张便条。假设 到了上个月的所有便条,编写一个处理系统,读取上月的销售情况(自己设定),进行如下处理:1、计算上个月没人每种产品的销售额2、按销售额对销售员进行排序,输出排序结果(销售员代号)3、统计每种产品的总销售额,对这些产品从高到低的顺序输出结果(须输出产品的代号和销售额)4、输出统计报表2、需求分析 本程序将用到文件系
2、统,list.txt文件内容作为数据源,其中单行内容代表一张纸条。程序运行后首先将文件系统的原始数据读取并保存到程序的结构体数组当中,所以应提供文件输入的操作;由于纸条数据零散,所以要对原始数据进行分类操作并提供一个数组用于保存分类信息;在程序中要进行统计工作,所以要提供显示、排序等操作;另外应提供键盘式选择菜单实现功能选择。3、功能实现设计3.1总体设计根据上面的分析,可以将这个系统分为如下五大模块:查看每人每种产品的销售额 、按销售额对销售员排序、对每种产品总销售额从高到低排序、输出统计报表和退出。其中主要模块是前四个模块。3.2流程图3.3详细设计: 【头文件和预定义】#include#
3、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【数据结构】原始数据有销售员代号、产品代号和销售额,所以定义一个全局结构体数组scrip用于保存原始数据。然后定义全局变量n保存纸条数目,定义数组s用于保存分类后的信息。struct ss int sid; /销售员代号 int pid; /产品代号 int sn; /销
4、售额 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(); /根据文件初始数据初始化便于操作的数组menu(); /显示主菜单3.3.4-1【文件读取函数】readdata()读出便条中的内容,并保存到文件结构体中void readdata() /从文件读取数据 FILE *fp; /定义文件指针 if
5、(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()将保存到结构体中的信息按产品分类,再根据销售员进行分类,将信息存到数组当中。 void foreach() /从纸条读取数据并分类整理 int i; for(i=0;in;i+) /遍历所有纸条 switch(ssi.pi
6、d) /按产品分大类,根据大类分销售员小类,累加各人各产品销售数量 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; bre
7、ak; 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) ca
8、se 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():计算上个月每个人每种产品的销售额seller():按销售额对销售员进行排序,输出排序结果(销售员代号)product():统计每种产品的总销售额,对这些产品按从高到低的顺序输出排序结果(需输出产品代号和销售额)exit(0):退出系统 void menu(
9、) 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): bb); scanf(%d,&c); if(c5) /错误输入则重新获取输入 w=1 else w=0; while(w=1); switch(c) /根据输入实现相应函数调用 case 1: detail();b
10、reak;/每个销售员每种产品的销售额统计 case 2: seller();break; case 3: product();break; case 4: total();break; case 5: exit(0); 【功能函数】5-1【每人每种产品销售额统计函数】detail() 计算上个月每个人每种产品的销售额void detail() /显示销售情况 int i,j; for(i=0;i4;i+) /遍历销售员 printf(ntt%d号销售员销售情况:n,i+1); for(j=0;j5;j+) /按销售员分类遍历所有产品并显示信息 printf(tt%d号产品销售数量:%dn,j
11、+1,sij); choice();【销售员销售业绩排序函数】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+) /比较四次,每次选出最大数 k=0; /用于标记单轮最大数 for(j=0;j4;j+) if(spkspj)k=j; /获取最大数标号 printf(tt第%d名是%d号销售员!n,i+1,k+1);spk=-1; /输出最大数和排名,将
12、最大数标记为负 choice();【总销售额统计函数】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;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();【统计报表输出函数】total(
13、)统计每种产品的总销售额,对这些产品按从高到低的顺序输出排序结果(需输出产品代号和销售额)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、运行结果(附带抓图)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 13 3 43 4 53 5 64 1 24 2 34
14、3 44 4 54 5 6运行结果 显示主菜单: 查看每人每种产品的销售额运行结果:按销售额对销售员按顺序排序(销售员代号)运行结果对每种产品销售额从高到低排序运行结果:统计报表运行结果:5、总结 通过这次C程序设计,我掌握了模块化设计方法,能够深入的理解结构化程序设计思想,熟练运用结构化程序设计方法,提高了运用C语言进行程序设计的能力。虽然刚开始我对文件的读写感到很茫然,但是通过查找网上资料和翻阅有关书籍,我逐渐领悟了文件读写的核心思想。因此,对于文件读写的操作。更重要的是对程序的调试有了显著的提高。我发现我对程序的设计越来越感兴趣了,我决定今后在这一方面下一番功夫,取得一些成绩。6、源程序
15、#include #include#include /*调用exit函数*/#include#define M 155 /*宏定义*/void detail();void foreach();void menu();void product();void readdata();void seller();void total();void choice();struct ss int 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;
16、 /用于保存员工和产品信息void main() /入口函数,即主函数 p readdata(); /读取文件数据 foreach(); /根据文件初始数据初始化便于操作的数组 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
17、(fp); void foreach() /从纸条读取数据并分类整理 int i; for(i=0;in;i+) /遍历所有纸条 switch(ssi.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; cas
18、e 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; case 2:s13+=ssi.sn;break; case 3:
19、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; void menu() int w,c; do puts(tt*菜单*nn); puts(tt 1.查看每人每种产品的销售额n); puts(tt 2.按销售额对销售员排序(销售员代号)n); puts(tt 3.对每种产
20、品总销售额从高到低排序(产品代号和销售额)n); puts(tt 4.输出统计报表n); puts(tt 5.退出n); puts(nntt*n); printf(请选择(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();br
21、eak; case 5: exit(0); void detail() /显示销售情况 int 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();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+) /比较四次
22、,每次选出最大数 k=0; /用于标记单轮最大数 for(j=0;j4;j+) if(spkspj)k=j; /获取最大数标号 printf(tt第%d名是%d号销售员!n,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第%
23、d名是%d号产品!t销量为%d!n,j+1,k+1,pk);pk=-1; choice();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);摘 要随着零售商店规模的发展,商品种类数量急剧增加,有关商品的各种信息量也成倍增长。商店时时刻刻都需要对商品各种信息进行统计分析。而很多零售商店仍然采用人工记账的传统方法,既容易出错又会导致账目混乱,查询和统计起来也非常不方便,费时又费
24、力,甚至会给商店造成损失。如何做好销售管理,使整个商店协调一致、高效率地运转,是各零售商店急待解决的问题。本设计主要根据实际需求,划分了销售登记,销售排行,销售明细,销售查询和系统设定五大模块,并使用C语言和 SQL Server 2005数据库,采用B/S模式实现了零售商店商品销售中多个模块的设计,满足了零售商店销售管理流程的功能需求。零售商店销售管理系统操作简单,账目清晰。通过账目查询,商店能在最短的时间内获得市场信息,从而制订相应的决策。关键词:销售管理;B/S模式;数据库;C#AbstractWith the retail store scale development, commodity quantity sharp growth, related commodity each kind of information also doubled. Store need to
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1