小伙伴说在运营中有很多促销活动,甚至包括双十一之类的。但每次活动的区间和长短都可能不同,希望可以对比不同日期区间的逐日对比活动细节。但在 PowerBI 中很难实现,是否可以实现呢。
今天我们就来看这个问题。
实现效果
对于这种有意义的问题,我们会提供尽量优质的解决方案的。如下:
用户选择两个活动各自的活动区间,可能是完全不同的,然后按照逐日对比每日的效果。
实现方法
这个问题其实并不复杂,首先我们先看一个更加简洁的表示,如下:
这个效果更加简洁而不改变问题的实质。这里就要考虑两个重要问题:
- 两个日期区间的选择如何提供?
- 如何和原始数据模型进行联立?
设计实现
我们知道一个数据模型里都会有一个日期表,而在这里场景中,必须至少需要两个日期表来提供两个日期区间的选择。问题是:
- 一个默认数据模型日期表可以做到吗?
- 那用两个日期表可以吗?
- 还是用三个日期表呢?
一个默认的日期表是无法在一个页面分别扮演两个角色的。
这里为了让这个设计更加独立,所以选择根本不去实现默认日期表,而是分别为此案例场景分别创建两个日期表,如下:
代码语言:javascript复制Calendar.Left =
SELECTCOLUMNS( 'Calendar' , "Date" , [Date] )
Calendar.Right =
SELECTCOLUMNS( 'Calendar' , "Date" , [Date] )
接着,我们用通用的 X 轴滑杆作为序号即可,如下:
代码语言:javascript复制Option.X = GENERATESERIES(0, 100, 1)
这在我们的万能初学者模板里已经内置。
接着我们将需要展示的所有内容,用 DAX 计算的方式给出即可。
先给出日期的计算,如下:
代码语言:javascript复制Activity.Left.Date =
VAR DateBeginOfPeriod = MIN( 'Calendar.Left'[Date] )
VAR DateEndOfPeriod = MAX( 'Calendar.Left'[Date] )
VAR Offset = SELECTEDVALUE( 'Option.X'[Option.X] )
VAR Result = DateBeginOfPeriod Offset
RETURN IF( Result <= DateEndOfPeriod , Result )
非常简单。
再给出对应日期的值的计算,如下:
代码语言:javascript复制Activity.Left.Value =
CALCULATE( [Start:KPI] , TREATAS( { [Activity.Left.Date] } , 'Calendar'[Date] ) )
更简单。
用已经计算的日期,动态挂载回数据模型计算即可。
由于左右是完全对称的结果,类似给出右边的计算即可。
完毕。
总结
很多有意义的业务场景,通过数据模型的合理布局,以及计算逻辑的精巧设计,很快就可以得到不错的方法。
值得一提的是,这里默认将非侵入式设计作为了原则,两个日期表都是为了作图存在,所以独立创建。