一:本文思维导图及示例数据图

1.1思维导图

1.2  示例数据图

二:度量值示例

2.1 函数简介

RANKX 首先为的每一行计值表达式,将结果临时存储为一个值列表。然后在当前筛选上下文中计值,将得到的结果与列表中的值进行比较,根据排名规则和的设置,返回最终排名。

2.2 产品排名(稠密)度量值

这个公式使用RANKX函数计算每个产品的销售排名。它使用稠密排名,这意味着当有相同值时,排名将紧密排列。
- 第一个参数`ALL('销售模拟表'[产品])`是一个表,它定义了要进行排名的数据集。在这种情况下,我们使用`ALL`函数来移除任何筛选器,以便在整个`'销售模拟表'[产品]`列中计算排名。
- 第二个参数`[产品销量]`是一个表达式,它返回每行的产品销量。RANKX函数将使用这个表达式的值来计算排名。
- 第三个参数被省略了。这意味着RANKX函数将使用第二个参数`[产品销量]`的值作为要查找排名的值。
- 第四个参数`DESC`指定排名的顺序。在这种情况下,我们使用降序排名。
- 第五个参数`DENSE`定义了当有相同值时如何确定排名。在这种情况下,我们使用稠密排名。
整个公式被包含在一个`IF`函数中,它检查是否只选择了一个产品。如果只选择了一个产品,那么公式将返回该产品的排名。否则,整个公式的结果为空。

产品排名(稠密) =
IF (
HASONEVALUE ( '销售模拟表'[产品] ),
RANKX (
ALL ( '销售模拟表'[产品] ), ---第一参数,table,表或者返回表的表达式
[产品销量], ---第二参数,expression,沿着table每行计值的表达式
, ---value,标量值,指单一的数值,可以是数字、数量、文本、日期或者布尔值
DESC, ---排序依据,
DENSE ---处理同排名的依据,skip,稀疏排名,sense,稠密排名
)
)

2.3  产品排名(稀疏)(HASONEVALUE)

同上,只是这里没有选择 TIES 参数,所以默认为SKIP参数

产品排名(稀疏)(HASONEVALUE) =
IF (
HASONEVALUE ( '销售模拟表'[产品] ),
RANKX (
ALL ( '销售模拟表'[产品] ),
[产品销量],
,
DESC
)
)

2.4  产品排名(稀疏)(SELECTEDVALUE)

这个公式使用RANKX函数计算每个产品的销售排名。它使用跳过排名,这意味着当有相同值时,排名将跳过相同值的数量。

  • 第一个参数ALL('销售模拟表'[产品])是一个表,它定义了要进行排名的数据集。在这种情况下,我们使用ALL函数来移除任何筛选器,以便在整个'销售模拟表'[产品]列中计算排名。
  • 第二个参数[产品销量]是一个表达式,它返回每行的产品销量。RANKX函数将使用这个表达式的值来计算排名。
  • 第三个参数被省略了。这意味着RANKX函数将使用第二个参数[产品销量]的值作为要查找排名的值。
  • 第四个参数DESC指定排名的顺序。在这种情况下,我们使用降序排名。
  • 第五个参数SKIP定义了当有相同值时如何确定排名。在这种情况下,我们使用跳过排名。

整个公式被包含在一个IF函数中,它检查是否只选择了一个产品。如果只选择了一个产品,那么公式将返回该产品的排名。否则,整个公式的结果为空。

与我们上面的公式不同,这个公式使用SELECTEDVALUE函数来检查是否只选择了一个产品。如果只选择了一个产品,SELECTEDVALUE函数将返回该产品的值。否则,它将返回空值。

我们使用ISBLANK函数来检查SELECTEDVALUE函数的返回值是否为空。如果返回值为空,那么整个公式的结果也为空。否则,我们使用RANKX函数计算产品的排名。

产品排名(稀疏)(SELECTEDVALUE) =
IF (
ISBLANK (
SELECTEDVALUE ( '销售模拟表'[产品] )
),
BLANK (),
RANKX (
ALL ( '销售模拟表'[产品] ),
[产品销量],
,
DESC,
SKIP
)
)

2.5  可见排名

有时我需要只统计当前可见的产品排名,那么,只需要将上方的ALL更改为ALLSELECTED即可

产品排名(稀疏)_只统计可见排名 =
IF (
ISBLANK (
SELECTEDVALUE ( '销售模拟表'[产品] )
),
BLANK (),
RANKX (
ALLSELECTED ( '销售模拟表'[产品] ),
[产品销量],
,
DESC,
SKIP
)
)

比如,这里,我们只选择了A,B,C,F四个产品,那么排名逻辑就会只排名现在已经被选择的产品,而前面的度量值会按所有产品进行排名。

三:注意事项

不要忘记ALL函数以及第二参数CALCULATE。

其他注意事项,后续博主使用中如有问题,会单独开文罗列。

以上,如果本文有帮到你,希望点赞支持一下。感谢!

#Powerbi 10分钟,理解 Rankx 排名函数的更多相关文章

  1. [转帖]SQL Server 10分钟理解游标

    SQL Server 10分钟理解游标 https://www.cnblogs.com/VicLiu/p/11671776.html 概述 游标是邪恶的! 在关系数据库中,我们对于查询的思考是面向集合 ...

  2. 10分钟理解BFC原理

    10 分钟理解 BFC 原理 一.常见定位方案 在讲 BFC 之前,我们先来了解一下常见的定位方案,定位方案是控制元素的布局,有三种常见方案: 普通流 (normal flow) 在普通流中,元素按照 ...

  3. T-SQL查询进阶-10分钟理解游标

    转:http://www.cnblogs.com/CareySon/archive/2011/11/01/2231381.html 概述 游标是邪恶的! 在关系数据库中,我们对于查询的思考是面向集合的 ...

  4. SQL Server 10分钟理解游标

    概述 游标是邪恶的! 在关系数据库中,我们对于查询的思考是面向集合的.而游标打破了这一规则,游标使得我们思考方式变为逐行进行.对于类C的开发人员来着,这样的思考方式会更加舒服. 正常面向集合的思维方式 ...

  5. 10分钟理解JS引擎的执行机制

    首先,请牢记2点: (1) JS是单线程语言 (2) JS的Event Loop是JS的执行机制.深入了解JS的执行,就等于深入了解JS里的event loop 1.灵魂三问 (1) JS为什么是单线 ...

  6. 10 分钟理解 BFC 原理

    一.常见定位方案 在讲 BFC 之前,我们先来了解一下常见的定位方案,定位方案是控制元素的布局,有三种常见方案: 普通流 (normal flow) 在普通流中,元素按照其在 HTML 中的先后位置至 ...

  7. 10分钟理解Android数据库的创建与使用(附具体解释和演示样例代码)

    1.Android数据库简单介绍. Android系统的framework层集成了Sqlite3数据库.我们知道Sqlite3是一种轻量级的高效存储的数据库. Sqlite数据库具有以下长处: (1) ...

  8. 10分钟理解React生命周期

    前言 学习React,生命周期很重要,我们了解完生命周期的各个组件,对写高性能组件会有很大的帮助. 一.简介 React /riˈækt/ 组件的生命周期指的是组件从创建到销毁过程中所经历的一系列方法 ...

  9. 对iOS后台模式最多10分钟运行时间的进一步理解

    在app进入后台时,系统初始默认是只有10s的处理时间,但如果10s不够,我们可以主动申请,网上流传最多的一个说法是10分钟. 但这种说法有个前提: 那就是iOS7之前,是这样 但从iOS7开始,我们 ...

  10. 智能合约语言 Solidity 教程系列10 - 完全理解函数修改器

    这是Solidity教程系列文章第10篇,带大家完全理解Solidity的函数修改器. Solidity系列完整的文章列表请查看分类-Solidity. 写在前面 Solidity 是以太坊智能合约编 ...

随机推荐

  1. Restless API 与 Restful API

    Restful  API: 1.CURD(增删改查) 由请求方式决定 2.请求方式有:get/post/delete/put 3.同一个路径可以进行多个操作 Restless API 1.CURD(增 ...

  2. react中子组件给父组件传值

    组件间通信:  React中,数据是从上向下流动的,也就是一个父组件可以把它的 state/props通过props传递给它的子组件,但是子组件,不能修改props,如果组件需要修改父组件中的数据,则 ...

  3. vue前端路由的两种模式,hash与history的区别

    1.直观区别: hash模式url带#号,history模式不带#号. 2.深层区别: hash模式url里面永远带着#号,我们在开发当中默认使用这个模式. 如果用户考虑url的规范那么就需要使用hi ...

  4. NC51101 Lost Cows

    题目链接 题目 题目描述 \(N (2 \leq N \leq 8,000)\) cows have unique brands in the range 1..N. In a spectacular ...

  5. jdk环境配置已经版本切换

    下载安装jdk到电脑盘,两个版本要下载到一个盘里面下安装好后右击我的电脑 找到高级系统设置,点开环境变量 新建环境变量 总计环境变量一共添加四个其中 java8和java11是是选择文件路径 JAVA ...

  6. OCR 文字检测(Differentiable Binarization --- DB)

    文本检测 基于分割的做法(如蓝色箭头所示): 传统的pipeline使用固定的阈值对于分割后的热力图进行二值化处理 首先,它们设置了固定的阈值,用于将分割网络生成的概率图转换为二进制图像 然后,用一些 ...

  7. Crackme逆向分析365例-001

    [Crackme逆向分析365例-001]    表哥是神,误落凡尘 说明:本篇练习是表哥逆向分析365系列的第1例,所使用的CrackMe本体来自于网站:https://crackmes.one/, ...

  8. 2022-07-07:原本数组中都是大于0、小于等于k的数字,是一个单调不减的数组, 其中可能有相等的数字,总体趋势是递增的。 但是其中有些位置的数被替换成了0,我们需要求出所有的把0替换的方案数量:

    2022-07-07:原本数组中都是大于0.小于等于k的数字,是一个单调不减的数组, 其中可能有相等的数字,总体趋势是递增的. 但是其中有些位置的数被替换成了0,我们需要求出所有的把0替换的方案数量: ...

  9. 2021-07-16:三个无重叠子数组的最大和。给定数组 nums 由正整数组成,找到三个互不重叠的子数组的最大和。每个子数组的长度为k,我们要使这3*k个项的和最大化。返回每个区间起始索引的列表(索

    2021-07-16:三个无重叠子数组的最大和.给定数组 nums 由正整数组成,找到三个互不重叠的子数组的最大和.每个子数组的长度为k,我们要使这3*k个项的和最大化.返回每个区间起始索引的列表(索 ...

  10. 【GiraKoo】安装Visual Assist失败,提示“此扩展已经安装到所有适用的产品”

    [问题解决]安装Visual Assist失败,提示"此扩展已经安装到所有适用的产品" 在安装Visual Assist插件时,提示错误. 点击下一步之后,进入插件安装界面.插件安 ...