一:数据源

模拟数据为三款奶茶销量的日销售数据源,日期是23.8.24-23.8.31。A产品为连续7天,日环比下降,B产品为连续3天,日环比下降,C产品为连续2天,日环比下降。

二:建立基础度量值

首先,我们建立两个基础度量值,计算我们的产品销量和日环比。

产品销量 = CALCULATE(SUM('数据源'[销量]))
产品销量日环比 =
VAR T1 = CALCULATE([产品销量],DATEADD('日期表'[Date],-1,DAY))
RETURN DIVIDE([产品销量]-T1,T1)  

三:建立异常下降度量值

产品销量_是否最近N天持续下降 =
VAR N='参数'[参数_值] ///控制天数,可以是一个固定的值,也可以是一个字段参数,动态的值
VAR T1 =
SUMMARIZE(FILTER('日期表','日期表'[Date]>=MAX('日期表'[Date])-N&&'日期表'[Date]<=MAX('日期表'[Date])-1),'日期表'[Date])
VAR T2 =
ADDCOLUMNS(T1,"产品日环比",[产品销量日环比])
VAR T3= FILTER(T2,[产品销量日环比]<0)
RETURN IF(COUNTROWS(T3)=N,"连续下降")

 

四:异常下降代码解释

首先,VAR N 是一个数值,可以是一个具体的值,如果是3,那么就是检测是否为连续3天下降,如果是7,那么就是检测是否为连续7天下降。这里使用的是参数表的值,也就意味着可以让报表使用者,自行选择对应的下降指标去查看数据。

然后,VAR T1 是一个表,但是他只有一个日期列,日期列是根据数据源的最大日期,往前倒退N天。这里我们用powerbi的新建表去看看这行代码,返回的是什么表。如下所示,返回的是数据源表最大日期,往前倒退7天的一个日期表。

再然后,VAR T2 是在T1日期列的基础上,新增一列,列名是"产品日环比",值是我们前面计算的基础度量值[产品销量日环比]。现在我们T2有两列了,一列是日期,一列是销量日环比

再然后,  VAR T3 是在T2表的基础上,我们用FILTER把日环比小于0的行数抓出来,也就是我们把日环比小于0,下降的天数的行给筛选出来。

最后一步,就是收尾的一步了,既然我们已经把日环比小于0的行,找出来了。我们对他的行进行计数,再和我们前面的N去进行对比,如果和N相等就意味着所有的天数均在下降,符合我们RETURN的IF语句,就输出"连续下降",如果不符合连续下降,我们就不返回值。(这里我们思考一下,以B产品为例,如果N等于3,而实际B产品日环比小于0的只有2天,所以这里返回的值就是2,那么2不等于3,所以是不会返回值的,反之如果N=2那么,2=2就会正常返回”连续下降”)

这样我们就可以灵活的查看异常指标了。

我们来看一下简单的结果展示。准确的抓到了连续2天,连续3天,以及连续7天下降的产品。

如果对前面讲的东西不太理解,可能是咱们基础比较弱,可以补充补充基础知识再来看。

有了这个模块的知识,我们就可以根据自己的思路,去构建异常指标的看板了,有了思路,剩下的就请交给DAX吧。

ENJOY DAX -SIMONE

POWERBI_1分钟学会_连续上升或下降指标监控的更多相关文章

  1. PHP学习过程_Symfony_(3)_整理_十分钟学会Symfony

    这篇文章主要介绍了Symfony学习十分钟入门教程,详细介绍了Symfony的安装配置,项目初始化,建立Bundle,设计实体,添加约束,增删改查等基本操作技巧,需要的朋友可以参考下 (此文章已被多人 ...

  2. 【grunt第二弹】30分钟学会使用grunt打包前端代码(02)

    前言 上一篇博客,我们简单的介绍了grunt的使用,一些基础点没能覆盖,我们今天有必要看看一些基础知识 [grunt第一弹]30分钟学会使用grunt打包前端代码 配置任务/grunt.initCon ...

  3. 5分钟学会使用Less预编译器

    5分钟学会使用Less预编译器 Less是什么? LESS CSS是一种动态样式语言,属于CSS预处理语言的一种,它使用类似CSS的语法为CSS赋予了动态语言的特性,如变量.继承.运算.函数等,更方便 ...

  4. 【公众号系列】两分钟学会SAP F1技巧

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[公众号系列]两分钟学会SAP F1技巧   写 ...

  5. 10分钟学会搭建Android开发环境 Eclipse: The import android.support cannot be resolved

    10分钟学会搭建Android开发环境_隋雨辰 http://v.youku.com/v_show/id_XNTE2OTI5Njg0.html?from=s1.8-1-1.2 The import a ...

  6. 《量化投资:以MATLAB为工具》连载(2)基础篇-N分钟学会MATLAB(中)

    http://www.matlabsky.com/thread-43937-1-1.html   <量化投资:以MATLAB为工具>连载(3)基础篇-N分钟学会MATLAB(下)     ...

  7. 《量化投资:以MATLAB为工具》连载(1)基础篇-N分钟学会MATLAB(上)

    http://blog.sina.com.cn/s/blog_4cf8aad30102uylf.html <量化投资:以MATLAB为工具>连载(1)基础篇-N分钟学会MATLAB(上) ...

  8. [分享] 史上最简单的封装教程,五分钟学会封装系统(以封装Windows 7为例)

    [分享] 史上最简单的封装教程,五分钟学会封装系统(以封装Windows 7为例) 踏雁寻花 发表于 2015-8-23 23:31:28 https://www.itsk.com/thread-35 ...

  9. 50分钟学会Laravel 50个小技巧

    50分钟学会Laravel 50个小技巧 时间 2015-12-09 17:13:45  Yuansir-web菜鸟 原文  http://www.yuansir-web.com/2015/12/09 ...

  10. 10分钟学会Linux

    10分钟学会Linux有点夸张,可是能够让一个新手初步熟悉Linux中最重要最主要的知识,本文翻译的英文网页在众多Linux入门学习的资料中还是很不错的. 英文地址:http://freeengine ...

随机推荐

  1. input 文件上传 formdata

    需求背景 后端给定接口 传xlsx文件 参数:后台需要的参数 格式: formdata 需要   token 1 saveEditIn (e) { 2 this.sheetAll = [] 3 // ...

  2. Prism进入视图时导航的三种方式

    Prism导航 新建视图UserControl及其ViewModel,被跳转的视图的VM需要实现INavigationAware 在App.xaml.cs中注册视图及其ViewModel // App ...

  3. 【python基础】文件-文件路径

    1.文件路径 我们发现不管是写入还是写出操作,我们提供的都是文件名,其实这里准确说应该是文件路径.当我们简单把文件名传递给open函数时,Python将在当前执行程序的文件所在的目录中查找文件名所代表 ...

  4. stream流根据集合中的元素的属性进行去重的方法

    public class StreamListTest { public static void main(String[] args) { List<Student> studentLi ...

  5. Linux 上的 .NET 如何自主生成 Dump

    一:背景 1. 讲故事 前几天微信上有位朋友找到我,说他程序的 线程数 会偶发性瞬时飙高,让我看下大概是什么原因,截图如下: 如果这种问题每天都会出现,比较好的做法就是用 dotnet-trace 捕 ...

  6. CompletableFuture之批量上传

    前言 最近接到一个需求,批量上传图片到服务器及实时更新上传进度.当处理大量文件上传任务时,效率是一个关键因素.传统的串行方式会导致任务耗时较长,而使用并发处理可以极大地提高上传效率.想到很久之前用Co ...

  7. Redis核心技术与实践 02 | 数据结构:快速的Redis有哪些慢操作?

    原文地址:https://time.geekbang.org/column/article/268262 博客地址:http://njpkhuan.cn/archives/redis-he-xin-j ...

  8. linux基础命令及常用命令总结

    1.ls命令 ls命令是最基础的命令之一,作用是列出当前目录下所有的文件和目录.ls命令有很多选项可以使用,比较常用的是-l选项,可以以详细信息的形式列出所有文件和目录的信息. 示例:列出当前目录下的 ...

  9. MyBatis使用注解开发(及Sqlsession连接器的本质)

    使用注解开发 底层实现机制是反射和,动态代码.反射可以获得这个类的方法属性还可以创建对象,执行方法. 面向接口编程 之前学过,面向对象编程,也学习过接口.但是真正的开发中,很多时候我们会选择面向接口编 ...

  10. 语音合成技术汇总1:Glow-TTS:通过单调对齐实现文本到语音的生成流

    今天开始开一期语音合成经典论文的翻译 Glow-TTS:通过单调对齐实现文本到语音的生成流 摘要: 最近,文本到语音(Text-to-Speech,TTS)模型,如FastSpeech和ParaNet ...