C语言程序设计_销售管理系统
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
销售信息管理系统设计文档
组号:第二组
成员:汪品高齐瑞智欧阳鑫赵飞锋章森
目录
一.题目与要求
二.功能实现设计(模块化设计)三.运行结果(附带抓图)
四.源程序
报告正文
1、题目与要求:
2、某公司有四个销售员(编号:1-4),负责销售五种产品(编号:1—5)。每个销售员汇总当天出售得每种产品得销售情况。
2 每天销售情况包括(销售员得代号、产品得代号、这种产品当天得销售额)
1、编写一个销售信息管理系统,读取上个月得销售情况
1、计算上个月没人每种产品得销售额
2、按销售额对销售员进行排序,输出排序结果(销售员代号)
3、统计每种产品得总销售额,对这些产品从高到低得顺序输出结果(须
输出产品得代号与销售额)
4、输出统计报表
2、需求分析
本程序将用到文件系统E ://54321、doc 文件内容作为数据源,其中单行内容代表一张纸条.程序运行后首先将文件系统得原始数据读取并保存到程序得结构体数组当中,所以应提供文件输入得操作;由于纸条数据零散,所以要对原始数据进行分类操作并提供一个数组用于保存分类信息;在程序中要进行统计工作,所以要提供显示、排序等操作;另外应提供键盘式选择菜单实现功能选择。 3、功能实现设计
3、1总体设计
根据上面得分析,可以将这个系统分为如下五大模块:查瞧每人每种产品得销售额 、按销售额对销售员排序、对每种产品总销售额从高到低排序、输出统计报表与退出。其中主要模块就是前四个模块.
3、2流程图
ﻩ
3、3详细设计:
3、3、1【头文件与预定义】
#incl ud e〈st dio 、h 〉
#in cl ude
#i nclude <st dlib 、h〉
#inclu de #def in e M 3、3、2【功能函数声明】 vvoid deta il(); vo id fore ach(); voi d menu (); void prod uct() void re adda ta () ; void se ll e r(); void t otal(); v oid c hoice (); 3、3、3【数据结构】 原始数据有销售员代号、产品代号与销售额,所以定义一个全局结构体数组scrip 用于保存原始数据。然后定义全局变量n 保存纸条数目,定义数组s 用于保存分类后得信息。 struct ss { int sid; //销售员代号 int pid ; //产品代号 i nt sn ; //销售额 }s s[M ]; int n ; //纸条数目 in t s[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【主函数】 显示程序设计者相关信息与调用文件读取函数、数据初始化函数与主菜单函数void main()//入口函数,即主函数 { readdata(); //读取文件数据 foreach();//根据文件初始数据初始化便于操作得数组 menu(); //显示主菜单 } 3、3、4-1【文件读取函数】readdata() 读出便条中得内容,并保存到文件结构体中 void readdata() //从文件读取数据 { ﻩFILE *fp;//定义文件指针 ﻩif((fp=fopen("list、txt”,"r”))==NULL) ﻩ{ ﻩprintf("Can't open the file!\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() 将保存到结构体中得信息按产品分类,再根据销售员进行分类,将信息存到数组当中。 void foreach() //从纸条读取数据并分类整理 { ﻩint i; ﻩfor(i=0;i〈n;i++) //遍历所有纸条 { ﻩswitch(ss[i]、pid) ﻩﻩ //按产品分大类(例如就就是case1-—5),根据大类分销售员小类,累加各人各产品销售数量 ﻩﻩ{ ﻩ case 1: ﻩﻩﻩswitch(ss[i]、sid) ﻩ{ ﻩﻩﻩcase 1:s[0][0]+=ss[i]、sn;break; case 2:s[1][0]+=ss[i]、sn;break; ﻩﻩcase 3:s[2][0]+=ss[i]、sn;break; ﻩ case 4:s[3][0]+=ss[i]、sn;break; ﻩ } ﻩbreak; ﻩﻩﻩcase 2: ﻩﻩ switch(ss[i]、sid) ﻩﻩ{ ﻩﻩﻩ case 1:s[0][1]+=ss[i]、sn;break;