不写DAX实现TopN和其他

news/2024/5/4 2:51:46/文章来源:https://blog.csdn.net/bluefire5/article/details/127031066

最近状态不好,每天晚上回来基本都是会去骑行,所以一直没时间更新,特别是今天骑行了五十公里,着实是废了,骑行也要讲究循序渐进啊。

DAX实现TopN和其他

那么今天就来点轻松的内容,先前介绍过使用RANKX计算层级排名时有说到利用RANKX也可以实现TopN和其他,比如我们想知道每个类别Top3的商品销售和其他产品的销售,就像下面这样。

为了实现每个类别Other部门的销售额,首先需要构造一张包含商品名为Others的商品表

Product Names = 
UNION ( ALLNOBLANKROW ( 'Product'[Product Name] ), { "Others" } 
)

然后还要和产品表建立关系

之后还要重新写下销售额和排名的度量

Sales Amt = // topn和其他的商品销售额
VAR SalesOfAll =CALCULATE ([Sales Amount],REMOVEFILTERS ( 'Product Names' ))
RETURNIF (NOT ISINSCOPE ( 'Product Names'[Product Name] ),SalesOfAll,VAR ProductsToRank = [TopN 值]VAR SalesOfCurrentProduct = [Sales Amount]VAR IsOtherSelected =SELECTEDVALUE ( 'Product Names'[Product Name] ) = "Others"RETURNIF (NOT IsOtherSelected,SalesOfCurrentProduct,VAR VisibleProducts =  // 当前的商品名CALCULATETABLE (VALUES ( 'Product' ),ALLSELECTED ( 'Product Names'[Product Name] ))VAR ProductsWithSales =ADDCOLUMNS (VisibleProducts,"@SalesAmount", [Sales Amount])VAR SalesOfTopProducts =  // 对商品进行排序SUMX (TOPN (ProductsToRank,ProductsWithSales,[@SalesAmount]),[@SalesAmount])VAR SalesOthers =  // 总计-topn就是其他的SalesOfAll - SalesOfTopProductsRETURNSalesOthers))

排名

Ranking = 
SWITCH( TRUE(),ISINSCOPE ( 'Product Names'[Product Name] ),VAR ProductsToRank = [TopN 值]VAR SalesAmount = [Sales Amount]VAR IsOtherSelected =SELECTEDVALUE ( 'Product Names'[Product Name] ) = "Others"RETURNIF (IsOtherSelected, // 对其他进行排序-- Rank for OthersProductsToRank + 1,-- //对topN的商品进行排序IF (SalesAmount > 0,VAR VisibleProducts =CALCULATETABLE (VALUES ( 'Product' ),ALLSELECTED ( 'Product Names' ))VAR Ranking =RANKX (VisibleProducts,[Sales Amount],SalesAmount)RETURNIF (Ranking > 0 && Ranking <= ProductsToRank,Ranking))),ISINSCOPE ( 'Product'[Category] ),RANKX ( ALLSELECTED ( 'Product'[category] ),CALCULATE([Sales Amount],REMOVEFILTERS( 'Product Names' )))
)

占比

% Parent 7 = 
SWITCH( TRUE(),ISINSCOPE ( 'Product Names'[Product Name] ),DIVIDE( [Sales Amt], CALCULATE ( [Sales Amount],REMOVEFILTERS ( 'Product Names' ) ) ),ISINSCOPE ( 'Product'[Category] ),DIVIDE( [Sales Amount], CALCULATE( [Sales Amount], REMOVEFILTERS( 'Product Names' ), ALLSELECTED( 'Product' ) ))
)

相信这么长的代码已经可以劝退很多人了,特别是这还是最简单的情况,只是商品名层级有topN和其他,如果每一层都需要是Top+其他呢?至少,我已经开始崩溃了,那有没有什么方法可以快速来实现这样多变的TopN的需求呢?

Inforiver professional实现Topn和其他

使用Inforiver professional可以不用建新表,也不用写新的度量值,就可以快速实现TopN和其他的效果。

Sales Amount = SUMX ( Sales, Sales[Quantity] * Sales[Net Price] )

设置起来也比较简单,应用商店加载这个图表就好(图表收费),然后找到TopN选项,设置我们需要展示topn的列即可

这里,设置每个层级都是Top3

效果如下,会发现每个层级都是Top3和其他,

也可以快速添加占比和排名

Inforiver professional实现

除了实现Topn和其他,该图表还可以实现其他功能,比如热力图,我们知道PowerBI中只能按列来添加条件格式,想实现一些特殊要求的条件格式,比如按行,或者按表就需要写很多度量值,而且使用Inforiver professional则可以轻松实现

再次感叹,第三方图表是真好用,微软能不能好好改进了自带图表的功能。下周就要国庆假期了,终于可以回家了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_13324.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

qt之页面布局

QTlayout概述 Qt的布局管理系统提供了强大的机制来自动排列窗口中的所有部件,确保它们有效地使用空间。Qt包含了一组布局管理类,从而在应用程序的用户界面中对部件进行布局,比如QLayout的几个子类,这里将它们称作布局管理器。所有QWidget的子类的实例(对象)都可以使用布局管理器…

路由多视图单页应用router-link相关属性

目录 1 vue中文件及文件夹命名规范 2 SPA 2.1 SPA简介 2.2 SPA技术点 3 使用路由建立多视图单页应用 3.1 引入依赖库 3.2 创建自定义组件 相关知识点&#xff1a; 3.3 创建路由 3.3.1 什么是路由 3.3.2 定义路由 3.4 创建和挂载根实例 3.5 使用RouterLink和Router…

线程池基本知识

文章目录1 问题背景2 前言3 线程池是什么4 线程池核心设计与实现4.1 总体设计4.2 运行机制4.3 生命周期管理4.4 任务执行机制4.4.1 任务调度4.4.2 任务缓冲4.4.3 任务申请4.4.4 任务拒绝4.5 Worker线程管理4.5.1 Worker线程1 问题背景 前面总结了工作中的解决方案——电商项目之…

EEG巨型分析I:跨研究的频谱和振幅特征

导读 通过汇集多项研究的统计结果(元分析)&#xff0c;fMRI领域取得了重大成就。最近&#xff0c;fMRI标准化工作的重点是实现跨研究(巨型分析)的fMRI原始数据的联合分析&#xff0c;以期获得更详细的见解。然而&#xff0c;目前尚不清楚在EEG领域的此类分析是否可能或同样富有…

公众号如何搭建使用查题功能的方法

公众号如何搭建使用查题功能的方法 本平台优点&#xff1a; 多题库查题、独立后台、响应速度快、全网平台可查、功能最全&#xff01; 1.想要给自己的公众号获得查题接口&#xff0c;只需要两步&#xff01; 2.题库&#xff1a; 查题校园题库&#xff1a;查题校园题库后台&a…

Vue入门【三】-- 详解computed计算属性

目录 computed: ♡ ‧₊˚ 基本使用 ‧₊˚ ♡ ♡ ‧₊˚语法‧₊˚ ♡ ♡ ‧₊˚效果‧₊˚ ♡ ♡ ‧₊˚ 面试问点 ‧₊˚ ♡ computed与methods的区别&#xff1a; computed与watch的区别&#xff1a; computed: 首先我们要知道computed计算属性是什么&#xff0c;在v…

我是一名开发人员,但我不会教我的孩子编程

编程需要的不仅仅是儿童书籍中教授的简单干巴巴的语言。 长按关注《Python学研大本营》&#xff0c;加入读者群&#xff0c;分享更多精彩 在最近的一次深夜公式跑中&#xff0c;我路过一大堆关于教孩子编程的书籍。我在周围看过这些书&#xff0c;但从来没有这么大的针对小学生…

STM32时钟系统和TIMER配置(溢出中断/PWM)实例

目录&#xff1a; 1. STM32时钟系统 2. STM32的定时器典型配置之溢出中断 3. STM32的定时器典型配置之PWM输出 1. STM32时钟系统 &#xff08;1&#xff09;Clock tree 可以在官方手册(Stm32x-series-Reference-manual)的clock tree中可以对相应MCU的时钟系统有个大致了解…

数字信号处理——多速率信号处理(1)

目录 引言 1、抽取 MATLAB仿真代码 仿真结果 抽取滤波器 2、内插

《关于我摸鱼一天后搞定PyCharm这件事》Python环境配置

Anaconda部署 1.下载最新版匹配电脑的版本 我是 WIN-x64 下载Index of /anaconda/archive/ | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror 我是 Anaconda3-2022.05-Windows-x86_64 下载 社区版本Pycharm Download PyCharm: Python IDE for Professional Develo…

从零玩转jQuery(基础篇)

1.前言 &#xff08;window.onload和jQuery的相关介绍&#xff09; 分析一下&#xff0c;元素js的缺点: 1.不能添加多个入口函数&#xff08;window.onload),如果添加了多个&#xff0c;后面的会把前面的给覆盖。 2.原生js的api名字都太长太难记。 3.原生js有的时候代码冗余。 …

Maven坐标查找方法及Maven-Search 插件的使用(保姆级教学)

目录坐标的概念获取坐标方法一获取坐标方法二坐标的概念 坐标组成是groupid,artifiactld,version。坐标概念来自数学。 坐标作用:确定资源的&#xff0c;是资源的唯一标识。在maven中&#xff0c;每个资源都有坐标。坐标值是唯一的。简称叫gav。 拿servlet依赖举例 <!--serv…

nacos 简介和使用

Nacos 是阿里巴巴开源项目&#xff0c;用于构建微服务应用的服务发现、配置管理和服务管理。 在微服务项目中不同模块之间服务调用时&#xff0c;实现服务注册与发现。 Nacos 使用&#xff1a; Nacos 是java开发的&#xff0c;依赖 Java 环境来运行 Nacos的下载 https://git…

cobbler部署

cobbler部署 #先关闭防火墙和selinux [root@localhost ~]# systemctl disable firewalld [root@localhost ~]# setenforce 0 //cobbler服务,selinux必须得是disabled状态,所以要重启 [root@localhost ~]# vim /etc/selinux/config SELINUX=disabled [root@localhost ~]# reb…

BUUCTF-社团考核

目录 1.[CISCN2019 华东南赛区]Web4 2.[GWCTF 2019]枯燥的抽奖 3.[NCTF2019]Fake XML cookbook 4.[SCTF2019]Flag Shop 5.[GWCTF 2019]mypassword 6.[BSidesCF 2019]Kookie 7.[WUSTCTF2020]朴实无华 8.[网鼎杯 2020 白虎组]PicDown 9.[CISCN 2019 初赛]Love Math 10.攻…

深入ArrayList()源码

深入ArrayList()源码 jdk1.8 java.util; 扩容机制 新数组都将替代旧数组&#xff0c;旧数组作为垃圾被回收 ArrayList() 会使用长度为零的数组 private static final Object[] DEFAULTCAPACITY_EMPTY_ELEMENTDATA {};public ArrayList() {this.elementData DEFAULTCAPACITY…

采用 ALSTM 模型的温度和降雨关联预测研究论文学习记录

为了准确和及时预测局部区域的降雨及温度&#xff0c;提出了一种基于 Attention 和 LSTM 组合模型( ALSTM) 的关联多值预测算法。该算法利用天气时间序列中 的前期数据&#xff0c;对下一小时的降雨量和温度进行关联预测&#xff0c;以此实现对天气要素的多值预测。该算法首先对…

一个项目带你走进接口自动化测试

文章目录前言一、项目环境搭建二、项目分析三、框架搭建1、解决登录问题、获取token2、熟悉项目的接口请求方式、二次封装requests请求3、缓解业务请求接口参数臃肿4、重新封装logging日志5、通用方法编写四、编写自动化脚本场景业务需求单接口业务需求五、生成测试报告六、写在…

CSDN线上竞赛编程第六期参赛心得

CSDN编程竞赛报名地址&#xff1a;https://edu.csdn.net/contest/detail/16 &#xff08;请不要删掉此地址&#xff09; CSDN线上竞赛编程第六期参赛心得前言/背景大赛简介参赛流程参赛经历解题思路1、题目名称&#xff1a;严查枪火2、题目名称&#xff1a;鬼画符门3、题目名称…

HDMI/DVI____TMDS编码

一.编码步骤:基本方法:取第一位数据为初值,接下来输入的每一位与前一导出的位(根据判断条件)进行异或XOR或者同或XNOR(最小化传输);最后选择性反转这9bit数据(DC平衡处理)。 ①DE为高电平时,对8位RGB数据编码,第9bit表示采用了XOR / XNOR ,第10bit表示是否翻转。 …