BI技巧丨计算Topn品名

alt

BOSS:白茶,问你个事,能不能动态的根据我们的销量,告诉我销量前三的商品有哪些?这样便于我针对商品进行调控。

白茶:Topn问题?

BOSS:什么套不套的,我不懂,你就说能不能整吧!

白茶:(#%¥%@&@**@)没问题!

在日常工作中,我们往往需要根据各式各样的业务逻辑去计算相关指标的排名,以便于业务可以有针对性进行调控。

但是在某些业务场景下,其实需要的不仅仅是针对某个维度的排名,而是需要我们能够将排名前几的某些维度,作为结果呈现出来,以便进行向上汇报。

针对此需求,我们该如何在PowerBI实现呢?

案例数据:

alt alt alt

这是本期的案例数据,共计三张表,一张产品表,一张分店表,一张事实表。

将上述的三张表,导入到PowerBI中,模型关系如下:

alt

到这里,我们的准备工作结束。

基础指标:

销售数量:

001.Quantity = 
SUM ( 'Fact_Sales'[Quantity] )

销量排名:

002.Rankx = 
RANKX ( ALLSELECTED ( 'Dim_Product'[ProductName] ), [001.Quantity] )

将基础指标放在明细表中呈现,结果如下:

alt

那么,我们该如何计算销量前三品名呢?

方法1:利用Topn函数。

编写如下代码:

003.Topn = 
CONCATENATEX (
    TOPN ( 3, VALUES ( 'Dim_Product'[ProductName] ), [001.Quantity], DESC ),
    [ProductName],
    ",",
    [001.Quantity], DESC
)

结果如下:

alt

从结果上可以看到,我们利用Topn函数,根据销售数量,从ProductName字段中提取出了销量为前三的品名。

再通过CONCATENATEX函数将前三的品名拼接起来,“,”为分隔符。

方法2:利用CalculateTable函数。

编写如下代码:

004.CalculateTable = 
CONCATENATEX (
    CALCULATETABLE (
        VALUES ( 'Dim_Product'[ProductName] ),
        FILTER ( ALLSELECTED ( 'Dim_Product'[ProductName] ), [002.Rankx] <= 3 )
    ),
    [ProductName],
    ",",
    [001.Quantity], DESC
)

结果如下:

alt

在这个例子中,我们首先利用的是CalculateTable函数可以对表进行上下文重置的特性,以及Filter函数筛选出排名小于等于3的品名。

再通过CONCATENATEX函数将前三的品名拼接起来,“,”为分隔符。

对比Topn的写法,中间多了**[Rankx]函数**作为度量值中转,写法上绕了一下。

方法3:利用Calculate函数。

编写如下代码:

005.Calculate = 
VAR T1 =
    CALCULATE (
        MAX ( 'Dim_Product'[ProductName] ),
        FILTER ( ALLSELECTED ( 'Dim_Product'[ProductName] ), [002.Rankx] = 1 )
    )
VAR T2 =
    CALCULATE (
        MAX ( 'Dim_Product'[ProductName] ),
        FILTER ( ALLSELECTED ( 'Dim_Product'[ProductName] ), [002.Rankx] = 2 )
    )
VAR T3 =
    CALCULATE (
        MAX ( 'Dim_Product'[ProductName] ),
        FILTER ( ALLSELECTED ( 'Dim_Product'[ProductName] ), [002.Rankx] = 3 )
    )
VAR Result = T1 & "," & T2 & "," & T3
RETURN
    Result

结果如下:

alt

对比前面的两种写法,直接使用Calculate函数的计算显得粗暴了一些。

通过MAX这类函数可以对文本进行聚合的特性,再利用Filter函数依次筛选出排名为1、2、3的品名。

最终,通过“&”连接符,将三个结果拼接。

PS:

1.白茶其实更建议大家使用方法1,写法和性能上更优;

2.CalculateTable的写法对比方法1,稍微绕了一下,但是从内部结构上来讲比Topn函数好理解;

3.直接使用Calculate函数更适用于新手,简单粗暴,但是后续无法与参数搭配使用。

alt alt

这里是白茶,一个PowerBI的初学者。 alt

Fabric丨白茶 文章被收录于专栏

数据分析进阶之路,带你深入了解可视化技巧。

全部评论

相关推荐

ProMonkey2024:5个oc?厉害! 但是有一个小问题:谁问你了?😡我的意思是,谁在意?我告诉你,根本没人问你,在我们之中0人问了你,我把所有问你的人都请来 party 了,到场人数是0个人,誰问你了?WHO ASKED?谁问汝矣?誰があなたに聞きましたか?누가 물어봤어?我爬上了珠穆朗玛峰也没找到谁问你了,我刚刚潜入了世界上最大的射电望远镜也没开到那个问你的人的盒,在找到谁问你之前我连癌症的解药都发明了出来,我开了最大距离渲染也没找到谁问你了我活在这个被辐射蹂躏了多年的破碎世界的坟墓里目睹全球核战争把人类文明毁灭也没见到谁问你了(别的帖子偷来的,现学现卖😋)
点赞 评论 收藏
分享
点赞 1 评论
分享
牛客网
牛客企业服务