让决策更智能
新一代智能数据分析平台

快捷日期区间筛选器联动全局参数

观小远发表于:2022年04月14日 19:32:43更新于:2022年04月28日 11:41:29

场景

       页面上使用快捷日期区间筛选器,选择的快捷区间的总天数和数据集里同样范围的实际天数不一致时,计算出来的平均值也不同,仪表板制作者需要区分这两种情况。这时如果用普通的日期筛选器的话,可以联动两个日期类型全局参数来获取期初和期末日期,从而计算出总天数和平均值。但是使用快捷日期区间筛选器时,只能联动一个全局参数,没办法直接获取期初期末日期以及总天数。本文就介绍如何用快捷日期区间筛选器联动全局参数提取出期初期末日期。

案例

       页面上既支持选择快捷日期区间,也支持从日历里自由选择区间。指标卡里需要分别使用总天数和实际天数计算出日平均工单数;柱形图里,总天数小于21天时,维度为天;总天数小于60天时,维度为周;总天数超过60天时,维度为月份。参考下图效果。

0016258d3154921ba9c578d38159aa4

0016258d31571e5859b34d2e205c857

传参原理

       快捷日期区间筛选器,传参的时候是按照文本格式来处理的。例如,“最近7天”传的就是文本“最近7天”本身,需要用日期函数(跟当天current_date()作对比)来计算得到期初期末日期;但自由选择的2022-04-01~2022-04-03 传的是 “2022-04-01,2022-04-03 ",是期初和期末日期拼接起来的字符串,需要用拆分字符串的方式来获取期初期末日期。综上所述,需要使用文本型全局参数,不能使用日期型全局参数。

实现步骤

1.  在页面上新建一个快捷日期区间筛选器,先设置好可选项、默认值,勾选「提供日历区间选择」,暂时不设置联动。

001625805dde142f4f04439599eaea6

2.  在指标卡里按顺序新建以下计算字段:

参数」:文本类型;引用一个文本类型全局参数(单值多值皆可)。

期初」:日期类型;针对快捷区间,本案例里使用的昨天;针对自由区间, 使用 when instr([参数],',')>0 then date(split([参数],',')[0]) 来截取期初日期,逻辑为:判断参数里是否含有英文逗号,有的话说明是自由区间,用逗号把字符串拆分为数组,数组里共2个元素,数组后加[0]可以得到第1个元素(即期初日期),嵌套 date() 把文本型日期转换为日期格式。split([参数],',')[0] 非唯一用法,也可以使用 substring_index(([参数],',',1) 或其他方式获取期初日期。

期末」:日期类型;判断逻辑同上,split([参数],',')[1] 得到第2个元素,也可以使用 substring_index(([参数],',',-1) 获取期末日期。

日期判断」:布尔型;放入筛选栏(默认选TRUE),实现筛选区间范围内的日期。

001625805f40e53a39e93b741bc47e1

001625805f468146618a642ed5fc1aa

001625805f4530aee101a84bbf0fb38

3.  以上基础字段准备完毕,接下来新建计算字段计算卡片里要展示的数据。

「总天数」:数值型;公式 datediff([期末],[期初])+1 计算出区间内总天数;拖入数值栏,聚合方式选 “无处理”。

日均工单1/日均工单2数值型;公式如下图;拖入数值栏。

注意:预览无数据的话,在编辑页面右侧修改「参数默认值」来验证数据准确性。

0016258060f706715a5068612f08a53

0016258060fb2498c395cb2aa231ae8

4.  保存卡片,回到页面,把指标卡另存为一份到当前页面,切换类型为柱形图。新建计算字段「维度」,文本类型,拖入维度栏,预览无误后保存。

001625806342c181684e0484ca00697

0016258063564f38bd8146fedf28ffa

5.  设置筛选器联动,联动2个卡片里使用的全局参数即可。

00162580643f3d8eaa91de6b7bb9ee5

    您需要登录后才可以回复