第一范文网 - 专业文章范例文档资料分享平台

Excel制作动态WaterFall Analysis 方法详解

来源:用户分享 时间:2025/5/24 14:09:59 本文由loading 分享 下载这篇文档手机版
说明:文章内容仅供预览,部分内容可能不全,需要完整文档或者需要复制内容,请下载word后使用。下载word有问题请添加微信号:xxxxxxx或QQ:xxxxxx 处理(尽可能给您提供完整文档),感谢您的支持与谅解。

Excel制作动态WaterFall Analysis 方法详解(全)-包含VBA代码示例

Supply Chain S&OP 相关项目中往往会涉及Fcst 准确性分析,Water Fall Analysis 是一个很流行的分析手段。

通常Fcst tracking 有两个方向,一个是销售预测者和真实销售值的对比,另外一个是给供应商的预测订单数量和实际订单数量的对比。本文介绍后者在Excel中的作法。

1-首先建立两个表格放数据,Monthly Fcst , Monthly Sale,Monthly Fcst 表格存放历史上每个月Next 12 Month Fcst, Monthly Sales 则是每个月Actual Sale。高级一点的这两个表格也可以Link到数据库达到自动更新的效果。

2-设计一个新Sheet如上图,行和列名分别列出月份,旁边打1 到100 做辅助数据。 观察WaterFall 中规律有三点,

(1)行数和列数相等时为表格对角线的单元格,里面放销售值。 (2)列数比行数大时为上半部分表格,放预测值。 (2)列数比行数小时放空值。

有心的人可能会发现这是大学线性代数矩阵那一章节基本概念。

如果要显示不同供应商的Water Fall,在左上角加一个单元格叫Selection,里面放供应商名字给用户选择,这样就是一个动态Waterfall了。

在第一个单元格输入类似以下的公式,填充至所有,动态waterFall就大功告成了,如果你选择供应商A,waterFall 就会刷新成A的,如果选择(All)就是所有供应商的,因为(All)公式中是不识别的,所以要用Vlookup 把(All) 转成* ,*在sumif 的条件中表示所有。

=IF(L$1<$A12,\A:$A,$B12&L$2&$A$1,Total_Fcst!$F:$F)))

公式中L$1<$A12是判断单元格位置的,SUMIF(Actual_Order!$A:$A,$B12&L$2&$A$1,Actual_Order!$G:$G)是为了动态引用不同供应商。

3-加上些条件格式,如让对角线的值变红色等等,可以让分析结果更加一目了然。 4-添加双击可以Drill Down 到detail Data 功能。

在分析的时候,经常看到一个Fcst 或则Actual Order 很异常,想查下更加Detail Level的数据,看看什么原因。解决方法如下:

添加一张链接到Access的表格保护Detail的数据,在Excel中添加一个双击事件,把双击的单元格所对应的条件转化到Detail数据表格的筛选条件中。参考代码如下:

Private Sub Worksheet_BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean) If Target.Row >= 12 And Target.Column >= 11 And Len(Target.Value) > 1 Then

Dim Data_Month Dim ETD_month Dim catogory

With ThisWorkbook.Worksheets(\Data_Month = .Cells(Target.Row, 2).Value ETD_month = .Cells(2, Target.Column).Value catogory = .Range(\End With

With ThisWorkbook.Worksheets(\.AutoFilter

If Target.Row = Target.Column Then

‘如果双击单元格在对角线,则筛选Open order ,否则筛选Fcst. .AutoFilter Field:=1, Criteria1:=Data_Month + 0 .AutoFilter Field:=2, Criteria1:=\.AutoFilter Field:=10, Criteria1:=ETD_month .AutoFilter Field:=14, Criteria1:=catogory Else

.AutoFilter Field:=1, Criteria1:=Data_Month .AutoFilter Field:=10, Criteria1:=ETD_month .AutoFilter Field:=14, Criteria1:=catogory End If End With

ThisWorkbook.Worksheets(\ThisWorkbook.Worksheets(\End If End Sub 加完以上代码,

当双击WaterFall的值,则弹出以下DetailData做进一步的分析。

搜索更多关于: Excel制作动态WaterFall Analysis 方法 的文档
Excel制作动态WaterFall Analysis 方法详解.doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印
本文链接:https://www.diyifanwen.net/c7qumb8h9ev62h61030on_1.html(转载请注明文章来源)
热门推荐
Copyright © 2012-2023 第一范文网 版权所有 免责声明 | 联系我们
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ:xxxxxx 邮箱:xxxxxx@qq.com
渝ICP备2023013149号
Top