销售管理系统实用资料.docx

上传人:b****7 文档编号:23723333 上传时间:2023-05-20 格式:DOCX 页数:169 大小:1.91MB
下载 相关 举报
销售管理系统实用资料.docx_第1页
第1页 / 共169页
销售管理系统实用资料.docx_第2页
第2页 / 共169页
销售管理系统实用资料.docx_第3页
第3页 / 共169页
销售管理系统实用资料.docx_第4页
第4页 / 共169页
销售管理系统实用资料.docx_第5页
第5页 / 共169页
点击查看更多>>
下载资源
资源描述

销售管理系统实用资料.docx

《销售管理系统实用资料.docx》由会员分享,可在线阅读,更多相关《销售管理系统实用资料.docx(169页珍藏版)》请在冰豆网上搜索。

销售管理系统实用资料.docx

销售管理系统实用资料

报告正文

1、题目与要求:

1.1

某公司有四个销售员(编号:

1-4),负责销售五种产品(编号:

1-5)。

每个销售员都将当日出售的每种产品各写一张便条交上来。

每张便条内容有

1、销售员的代号

2、产品的代号

3、这种产品当天的销售额

1.2

每位销售员每天可能上缴0-5张便条。

假设到了上个月的所有便条,编写一个处理系统,读取上月的销售情况(自己设定),进行如下处理:

1、计算上个月没人每种产品的销售额

2、按销售额对销售员进行排序,输出排序结果(销售员代号)

3、统计每种产品的总销售额,对这些产品从高到低的顺序输出结果(须输出产品的代号和销售额)

4、输出统计报表

2、需求分析

本程序将用到文件系统,list.txt文件内容作为数据源,其中单行内容代表一张纸条。

程序运行后首先将文件系统的原始数据读取并保存到程序的结构体数组当中,所以应提供文件输入的操作;由于纸条数据零散,所以要对原始数据进行分类操作并提供一个数组用于保存分类信息;在程序中要进行统计工作,所以要提供显示、排序等操作;另外应提供键盘式选择菜单实现功能选择。

3、功能实现设计

3.1总体设计

根据上面的分析,可以将这个系统分为如下五大模块:

查看每人每种产品的销售额、按销售额对销售员排序、对每种产品总销售额从高到低排序、输出统计报表和退出。

其中主要模块是前四个模块。

3.2流程图

 

3.3详细设计:

【头文件和预定义】

#include

#include

#include

#include

#defineM

3.3.2【功能函数声明】

vvoiddetail();

voidforeach();

voidmenu();

voidproduct();

voidreaddata();

voidseller();

voidtotal();

voidchoice();

 

3.3.3【数据结构】

原始数据有销售员代号、产品代号和销售额,所以定义一个全局结构体数组scrip用于保存原始数据。

然后定义全局变量n保存纸条数目,定义数组s用于保存分类后的信息。

structss

{

intsid;//销售员代号

intpid;//产品代号

intsn;//销售额

}ss[M];

intn;//纸条数目

ints[4][5]={{0,0,0,0,0},{0,0,0,0,0},{0,0,0,0,0},{0,0,0,0,0}};//用于保存员工和产品信息

3.3.4【主函数】

显示程序设计者相关信息和调用文件读取函数、数据初始化函数和主菜单函数

voidmain()//入口函数,即主函数

{

readdata();//读取文件数据

foreach();//根据文件初始数据初始化便于操作的数组

menu();//显示主菜单

}

3.3.4-1【文件读取函数】readdata()

读出便条中的内容,并保存到文件结构体中

voidreaddata()//从文件读取数据

{

FILE*fp;//定义文件指针

if((fp=fopen("list.txt","r"))==NULL)

{

printf("Can'topenthefile!

\n");

exit(0);

}

else

for(n=0;!

feof(fp);n++)

{

fscanf(fp,"%d%d%d\n",&ss[n].sid,&ss[n].pid,&ss[n].sn);

}//保存文件数据到结构体

fclose(fp);

}

3.3.4-2【文件读取函数】foreach()

将保存到结构体中的信息按产品分类,再根据销售员进行分类,将信息存到数组当中。

voidforeach()//从纸条读取数据并分类整理

{

inti;

for(i=0;i

{

switch(ss[i].pid)

//按产品分大类,根据大类分销售员小类,累加各人各产品销售数量

{

case1:

switch(ss[i].sid)

{

case1:

s[0][0]+=ss[i].sn;break;

case2:

s[1][0]+=ss[i].sn;break;

case3:

s[2][0]+=ss[i].sn;break;

case4:

s[3][0]+=ss[i].sn;break;

}

break;

case2:

switch(ss[i].sid)

{

case1:

s[0][1]+=ss[i].sn;break;

case2:

s[1][1]+=ss[i].sn;break;

case3:

s[2][1]+=ss[i].sn;break;

case4:

s[3][1]+=ss[i].sn;break;

}

break;

case3:

switch(ss[i].sid)

{

case1:

s[0][2]+=ss[i].sn;break;

case2:

s[1][2]+=ss[i].sn;break;

case3:

s[2][2]+=ss[i].sn;break;

case4:

s[3][2]+=ss[i].sn;break;

}

break;

case4:

switch(ss[i].sid)

{

case1:

s[0][3]+=ss[i].sn;break;

case2:

s[1][3]+=ss[i].sn;break;

case3:

s[2][3]+=ss[i].sn;break;

case4:

s[3][3]+=ss[i].sn;break;

}

break;

case5:

switch(ss[i].sid)

{

case1:

s[0][4]+=ss[i].sn;break;

case2:

s[1][4]+=ss[i].sn;break;

case3:

s[2][4]+=ss[i].sn;break;

case4:

s[3][4]+=ss[i].sn;break;

};

break;}

}

}

3.3.4-3【主菜单函数】menu()

显示系统功能菜单以供用户选择相关功能使用,根据用户选择分别可调用

detail():

计算上个月每个人每种产品的销售额

seller():

按销售额对销售员进行排序,输出排序结果(销售员代号)

product():

统计每种产品的总销售额,对这些产品按从高到低的顺序输出排序结果(需输出产品代号和销售额)

exit(0):

退出系统

voidmenu()

{

intw,c;

do{

puts("\t\t*********菜单*********************\n\n");

puts("\t\t1.查看每人每种产品的销售额\n");

puts("\t\t2.按销售额对销售员排序(销售员代号)\n");

puts("\t\t3.对每种产品总销售额从高到低排序(产品代号和销售额)\n");

puts("\t\t4.输出统计报表\n");

puts("\t\t5.退出\n");

puts("\n\n\t\t*********************************************\n");

printf("请选择(1-5):

[]\b\b");

scanf("%d",&c);

if(c<1||c>5)//错误输入则重新获取输入

{

w=1

}

elsew=0;

}while(w==1);

switch(c)//根据输入实现相应函数调用

{

case1:

detail();break;//每个销售员每种产品的销售额统计

case2:

seller();break;

case3:

product();break;

case4:

total();break;

case5:

exit(0);

}

}

【功能函数】

5-1【每人每种产品销售额统计函数】detail()

计算上个月每个人每种产品的销售额

voiddetail()//显示销售情况

{

inti,j;

for(i=0;i<4;i++)//遍历销售员

{

printf("\n\t\t%d号销售员销售情况:

\n",i+1);

for(j=0;j<5;j++)

//按销售员分类遍历所有产品并显示信息

printf("\t\t%d号产品销售数量:

%d\n",j+1,s[i][j]);

}

choice();

}

【销售员销售业绩排序函数】seller()

按销售额对销售员进行排序,输出排序结果(销售员代号)

voidseller()

{

inti,j,k;

intsp[4]={0,0,0,0};

for(i=0;i<4;i++)

for(j=0;j<5;j++)

sp[i]+=s[i][j];

//计算每单个销售员所有产品销售数量

for(i=0;i<4;i++)//比较四次,每次选出最大数

{k=0;//用于标记单轮最大数

for(j=0;j<4;j++)

if(sp[k]

printf("\t\t第%d名是%d号销售员!

\n",i+1,k+1);sp[k]=-1;

//输出最大数和排名,将最大数标记为负

}

choice();

}

【总销售额统计函数】voidproduct()

统计每种产品的总销售额,对这些产品按从高到低的顺序输出排序

voidproduct()//与seller()原理一样,用于对产品进行统计

{

inti,j,k;

intp[5]={0,0,0,0,0};

for(j=0;j<5;j++)

for(i=0;i<4;i++)

p[j]+=s[i][j];

for(j=0;j<5;j++)

{

k=0;

for(i=0;i<5;i++)

if(p[k]

printf("\t\t第%d名是%d号产品!

\t销量为%d!

\n",j+1,k+1,p[k]);p[k]=-1;

}

choice();

}

【统计报表输出函数】total()

统计每种产品的总销售额,对这些产品按从高到低的顺序输出排序结果(需输出产品代号和销售额)

voidtotal()//输出报表

{inti,j;

printf("\n\t销售员\t产品\t销量\n");

for(i=0;i<4;i++)

for(j=0;j<5;j++)

printf("\t%d\t%d\t%d\n",i+1,j+1,s[i][j]);

choice();

}

【公共函数】

【选择函数】choice()

选择退出系统或则返回主菜单

voidchoice()//用于输出信息功能选择

{

intc;

printf("请选择接下来想做什么\t1>返回菜单\t2>退出系统[]\b\b");

scanf("%d",&c);

if(c==1)

menu();

else

exit(0);

puts('\n');

}

4、运行结果(附带抓图)

List.txt(便条)文件中数据如下:

111

122

133

148

159

213

223

234

245

256

311

321

334

345

356

412

423

434

445

456

运行结果

显示主菜单:

查看每人每种产品的销售额运行结果:

 

按销售额对销售员按顺序排序(销售员代号)运行结果

 

对每种产品销售额从高到低排序运行结果:

 

统计报表运行结果:

5、总结

通过这次C程序设计,我掌握了模块化设计方法,能够深入的理解结构化程序设计思想,熟练运用结构化程序设计方法,提高了运用C语言进行程序设计的能力。

虽然刚开始我对文件的读写感到很茫然,但是通过查找网上资料和翻阅有关书籍,我逐渐领悟了文件读写的核心思想。

因此,对于文件读写的操作。

更重要的是对程序的调试有了显著的提高。

我发现我对程序的设计越来越感兴趣了,我决定今后在这一方面下一番功夫,取得一些成绩。

6、源程序

#include

#include

#include/*调用exit函数*/

#include

#defineM155/*宏定义*/

voiddetail();

voidforeach();

voidmenu();

voidproduct();

voidreaddata();

voidseller();

voidtotal();

voidchoice();

structss

{

intsid;//销售员代号

intpid;//产品代号

intsn;//销售额

}ss[M];

intn;//纸条数目

ints[4][5]={{0,0,0,0,0},{0,0,0,0,0},{0,0,0,0,0},{0,0,0,0,0}};//用于保存员工和产品信息

voidmain()//入口函数,即主函数

{

p

readdata();//读取文件数据

foreach();//根据文件初始数据初始化便于操作的数组

menu();//显示主菜单

}

voidreaddata()//从文件读取数据

{

FILE*fp;

if((fp=fopen("list.txt","r"))==NULL)

{

printf("Can'topenthefile!

\n");

exit(0);

}

else

for(n=0;!

feof(fp);n++)

{

fscanf(fp,"%d%d%d\n",&ss[n].sid,&ss[n].pid,&ss[n].sn);

}//保存文件数据到结构体

fclose(fp);

}

voidforeach()//从纸条读取数据并分类整理

{

inti;

for(i=0;i

{

switch(ss[i].pid)

//按产品分大类,根据大类分销售员小类,累加个人各产品销售数量

{

case1:

switch(ss[i].sid)

{

case1:

s[0][0]+=ss[i].sn;break;

case2:

s[1][0]+=ss[i].sn;break;

case3:

s[2][0]+=ss[i].sn;break;

case4:

s[3][0]+=ss[i].sn;break;

}

break;

case2:

switch(ss[i].sid)

{

case1:

s[0][1]+=ss[i].sn;break;

case2:

s[1][1]+=ss[i].sn;break;

case3:

s[2][1]+=ss[i].sn;break;

case4:

s[3][1]+=ss[i].sn;break;

}

break;

case3:

switch(ss[i].sid)

{

case1:

s[0][2]+=ss[i].sn;break;

case2:

s[1][2]+=ss[i].sn;break;

case3:

s[2][2]+=ss[i].sn;break;

case4:

s[3][2]+=ss[i].sn;break;

}

break;

case4:

switch(ss[i].sid)

{

case1:

s[0][3]+=ss[i].sn;break;

case2:

s[1][3]+=ss[i].sn;break;

case3:

s[2][3]+=ss[i].sn;break;

case4:

s[3][3]+=ss[i].sn;break;

}

break;

case5:

switch(ss[i].sid)

{

case1:

s[0][4]+=ss[i].sn;break;

case2:

s[1][4]+=ss[i].sn;break;

case3:

s[2][4]+=ss[i].sn;break;

case4:

s[3][4]+=ss[i].sn;break;

};

break;

}

}

}

voidmenu()

{

intw,c;

do{

puts("\t\t********************菜单*********************\n\n");

puts("\t\t1.查看每人每种产品的销售额\n");

puts("\t\t2.按销售额对销售员排序(销售员代号)\n");

puts("\t\t3.对每种产品总销售额从高到低排序(产品代号和销售额)\n");

puts("\t\t4.输出统计报表\n");

puts("\t\t5.退出\n");

puts("\n\n\t\t*********************************************\n");

printf("请选择(1-5):

[]\b\b");

scanf("%d",&c);

if(c<1||c>5)//错误输入则重新获取输入

{

w=1;

getchar();

}

elsew=0;

}while(w==1);

switch(c)//根据输入实现相应函数调用

{

case1:

detail();break;//每个销售员每种产品的销售额统计

case2:

seller();break;

case3:

product();break;

case4:

total();break;

case5:

exit(0);

}

}

voiddetail()//显示销售情况

{

inti,j;

for(i=0;i<4;i++)//遍历销售员

{

printf("\n\t\t%d号销售员销售情况:

\n",i+1);

for(j=0;j<5;j++)

//按销售员分类遍历所有产品并显示信息

printf("\t\t%d号产品销售数量:

%d\n",j+1,s[i][j]);

}

choice();

}

voidseller()

{

inti,j,k;

intsp[4]={0,0,0,0};

for(i=0;i<4;i++)

for(j=0;j<5;j++)

sp[i]+=s[i][j];

//计算每单个销售员所有产品销售数量

for(i=0;i<4;i++)//比较四次,每次选出最大数

{k=0;//用于标记单轮最大数

for(j=0;j<4;j++)

if(sp[k]

printf("\t\t第%d名是%d号销售员!

\n",i+1,k+1);sp[k]=-1;

//输出最大数和排名,将最大数标记为负

}

choice();}

voidproduct()//与seller()原理一样,用于对产品进行统计

{inti,j,k;

intp[5]={0,0,0,0,0};

for(j=0;j<5;j++)

for(i=0;i<4;i++)

p[j]+=s[i][j];

for(j=0;j<5;j++)

{k=0;

for(i=0;i<5;i++)

if(p[k]

printf("\t\t第%d名是%d号产品!

\t销量为%d!

\n",j+1,k+1,p[k]);p[k]=-1;}

choice();

}

voidtotal()//输出报表

{inti,j;

printf("\n\t销售员\t产品\t销量\n");

for(i=0;i<4;i++)

for(j=0;j<5;j++)

printf("\t%d\t%d\t%d\n",i+1,j+1,s[i][j]);

choice();

}

voidchoice()//用于输出信息功能选择

{

intc;

printf("请选择接下来想做什么\t1>返回菜单\t2>退出系统[]\b\b");

scanf("%d",&c);

if(c==1)

menu();

else

exit(0);

puts('\n');

}

摘要

随着零售商店规模的发展,商品种类数量急剧增加,有关商品的各种信息量也成倍增长。

商店时时刻刻都需要对商品各种信息进行统计分析。

而很多零售商店仍然采用人工记账的传统方法,既容易出错又会导致账目混乱,查询和统计起来也非常不方便,费时又费力,甚至会给商店造成损失。

如何做好销售管理,使整个商店协调一致、高效率地运转,是各零售商店急待解决的问题。

本设计主要根据实际需求,划分了销售登记,销售排行,销售明细,销售查询和系统设定五大模块,并使用C#语言和SQLServer2005数据库,采用B/S模式实现了零售商店商品销售中多个模块的设计,满足了零售商店销售管理流程的功能需求。

零售商店销售管理系统操作简单,账目清晰。

通过账目查询,商店能在最短的时间内获得市场信息,从而制订相应的决策。

 

关键词:

销售管理;B/S模式;数据库;C#

Abstract

Withtheretailstorescaledevelopment,commodityquantitysharpgrowth,relatedcommodityeachkindofinformationalsodoubled.Storeneedto

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

当前位置:首页 > 初中教育 > 其它课程

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1