首页 星云 工具 资源 星选 资讯 热门工具
:

PDF转图片 完全免费 小红书视频下载 无水印 抖音视频下载 无水印 数字星空

PowerBI_一分钟学会利用ALLEXCPET分组计算(以计算门店开业前3天销售金额为例)

编程知识
2024年08月04日 22:23

在某些特殊场景,我们往往需要去计算一些特定的组别的聚合数据

今天,就以计算门店开业前3天的销售情况,来学习一下,利用计算列和DAX度量值,两种快捷计算此类问题的方案。

一:XMIND

二:示例数据

2.1 示例数据列说明

 为了方便验证和更清晰的检查结果,数据源只用了三列,分别是3个门店,分别为A,B,C,日期列,以及一列模拟的营业额数据。

2.2 计算目标

目标就是利用DAX或者计算列,计算出,每一家门店实际产生销售的前三天的营业额之和

三:计算列方案

首先,我们用计算列方案来解决。

遇到此类问题,最快捷或者说最直接的方式就是通过计算列给我们的每行数据进行数据标注,再通过CALCULATE计算器的筛选器,去筛选我们想要的标签,再得到结果

下方的计算列方案,第一步就是通过MIN函数求得最小得日期,由于我们是计算每个门店单独得最小日期得销售之和,所以这里使用了ALLEXCEPT,去除门店列得筛选,总而得到了每一个门店得开业前三天得数据标签。

最后,通过CALCULATE函数,对符合我们要求的数据,进行求和,便得出我们的结果。

具体DAX代码如下:

第一步,新增营业表的计算列

IsFirst3Days = 

VAR MinDate = CALCULATE(MIN('示例表'[日期]), ALLEXCEPT('示例表', '示例表'[门店]))

RETURN

IF(

    '示例表'[日期] >= MinDate && '示例表'[日期] <= MinDate + 2,

    "开业前三天门店日期",

    "其他"

)     

第二步,度量值计算营业额,利用第一步的标签来筛选并计算

 IsFirst3Days_营业额= 

    CALCULATE(SUM('示例表'[营业额]),

            '示例表'[IsFirst3Days]="开业前三天门店日期")

  

四:DAX方案

 那么有没有更加方便,或者说一步解决问题的方案呢?

当然有,我们来看看纯DAX的解决思路。

首先,思路和计算列方案是一样的,我们也是利用标签的形式去筛选表,然后直接对符合条件的行进行求和,即可得到目标值

下方DAX中,首先利用FILTER函数,对示例表进行筛选,配合ALLEXCEPT函数,去除表筛选条件,最后直接用CALCULATE函数进行聚合。

有一点不一样的是,计算列方案时,我们用了IF去进行判断,DAX方案中,我们用了并列条件,即同时满足这两个条件的行我们保留,小知识点,在DAX中我们会使用  "&&"  去表达我们的 "且" 这个概念。

最后,我们可以看到,两种方案的结果是一样的。

纯DAX方案:

TotalSalesFirst3Days = 

CALCULATE(

    SUM('示例表'[营业额]),

    FILTER(

        '示例表',

        '示例表'[日期] >= CALCULATE(MIN('示例表'[日期]), ALLEXCEPT('示例表', '示例表'[门店])) &&

        '示例表'[日期] <= CALCULATE(MIN('示例表'[日期]), ALLEXCEPT('示例表', '示例表'[门店])) + 2

    )

)

看到这里,有些朋友可能会问,为什么会在这里介绍两种方案,而不只介绍DAX呢,明明DAX一步就可以解决问题?

因为,即便计算组,会浪费内存,在大的数据集表中有相当大的性能限制,但是,在某些紧急情况(来不及构思DAX)或者某些特殊场景下,我们首先需要解决问题,我们是鼓励多一些的解决问题思路。

所以,在性能充足时,不必纠结解决方式,解决问题就好,性能优化的事情,我们放在后面解决也不迟。

五:关键DAX-ALLEXCEPT函数

5.1 语法

ALLEXCEPT(<table>, <column1>, <column2>, ...)

5.2 作用

ALLEXCEPT函数会返回一个表,该表删除了所有筛选器,除了那些应用于指定列的筛选器。这在需要对某些列进行聚合计算时非常有用,而不受其他列的筛选条件影响。

5.3 使用场景

计算占比:例如,你想计算某个城市在省份中的销售占比,可以使用ALLEXCEPT函数保留省份的筛选条件,移除其他筛选条件。

复杂的聚合计算:在进行复杂的聚合计算时,ALLEXCEPT可以帮助你控制哪些列的筛选条件被保留,哪些被移除,从而更灵活地进行数据分析。

5.4 其他类似函数

ALL:移除所有筛选器,返回整个表或列

ALL('销售数据')

ALLSELECTED:移除所有筛选器,但保留用户在视觉对象中选择的筛选器

ALLSELECTED('销售数据')

REMOVEFILTERS:移除指定列或表的筛选器。

REMOVEFILTERS('销售数据'[省份])

KEEPFILTERS:保留现有筛选器,并在此基础上添加新的筛选器。

CALCULATE([销售量], KEEPFILTERS('销售数据'[城市] = "成都"))

六:总结

实际业务中,这类根据特定分组,如小组,商品品类,具体门店等,进行统计的场景是很常见的,而今天讲到的ALLEXCEPT函数的灵活使用,恰恰可以帮助我们解决这类问题

这类问题,包含了日期,分组占比,分组排名等等一系列的场景,值得我们花时间去研究,后续如果有实际案例发生,我会做补充的案例说明。

ENJOY DAX 

 

From:https://www.cnblogs.com/simone331/p/18329117
本文地址: http://shuzixingkong.net/article/785
0评论
提交 加载更多评论
其他文章 实现一个终端文本编辑器来学习golang语言:第三章文本查看器part1
本章我们来完成文本编辑器的文件打开和查看功能,最后成品如上图。我们将分4步,逐渐完成本章所需功能。内容比较多,会分为两个部分,第一部分主要关注于“View视图”和“buffer及文本读取”。 如上图最终效果所示,我们希望在终端的最下方增加一个状态栏,能够展示当前被打开的文件和当前的光标位置。 同时我
实现一个终端文本编辑器来学习golang语言:第三章文本查看器part1 实现一个终端文本编辑器来学习golang语言:第三章文本查看器part1
【EF Core】自动生成的字段值
自动生成字段值,咱们首先想到的是主键列(带 IDENTITY 的主键)。EF Core 默认的主键配置也是启用 Identity 自增长的,而且可以自动标识主键。前提是代表主键的实体属性名要符合以下规则: 1、名字叫 ID、id、或 Id,就是不分大小写; 2、名字由实体类名 + Id 构成。比如,
【EF Core】自动生成的字段值 【EF Core】自动生成的字段值
从零体检一个魔塔社区模型(modelscope)最简单demo
从社区拿一个模型,比如以下这个链接 https://www.modelscope.cn/models/iic/cv_mobilenet-v2_bad-image-detecting 它的代码样例如下 from modelscope.pipelines import pipeline from mod
从零体检一个魔塔社区模型(modelscope)最简单demo 从零体检一个魔塔社区模型(modelscope)最简单demo
Vue Vine:带给你全新的 Vue 书写体验!
你好,我是 Kagol,个人公众号:前端开源星球。 上个月和 TinyVue 的小伙伴们一起参加了 VueConf 24 大会,有幸认识沈青川大佬,并了解了他的 Vue Vine 项目,Vue Vine 让你可以在一个文件中通过函数方式定义多个 Vue 组件,同时可以使用所有 Vue 的模板特性。
Vue Vine:带给你全新的 Vue 书写体验! Vue Vine:带给你全新的 Vue 书写体验! Vue Vine:带给你全新的 Vue 书写体验!
golang 指定权限是 0o755 而不是 0755
在Go语言中,当指定文件权限时,使用前缀 0o 来明确表示八进制数是一种推荐的做法。 这是因为在Go语言中,八进制字面量必须以 0o 或 0O 开头,后跟八进制数字(0-7)。 这种语法是从 Go 1.8 开始引入的,目的是为了减少由于 八进制 字面量与零开头的 十进制数 之间的混淆。 在更早的 G
推荐一款.NET开源、功能强大的二维码生成类库
前言 在日常开发需求中,生成二维码以分享文本内容或跳转至指定网站链接等场景是比较常见的。今天大姚给大家分享一款.NET开源(MIT License)、免费、简单易用、功能强大的二维码生成类库:QrCodeGenerator。 项目特点 跨平台兼容性:&#160;支持.NET Standard 2.0
推荐一款.NET开源、功能强大的二维码生成类库 推荐一款.NET开源、功能强大的二维码生成类库 推荐一款.NET开源、功能强大的二维码生成类库
C#.Net筑基-解密委托与事件
委托与事件是C#中历史比较悠久的技术,从C#1.0开始就有了,核心作用就是将方法作为参数(变量)来传递和使用。其中委托是基础,需要熟练掌握,编程中常用的Lambda表达式、Action、Func都是委托,包括事件也是基于委托实现的。
C#.Net筑基-解密委托与事件 C#.Net筑基-解密委托与事件 C#.Net筑基-解密委托与事件
【解决方案】Java 互联网项目中消息通知系统的设计与实现(下)
书接上回,消息通知系统(notification-system)作为一个独立的微服务,完整地负责了 App 端内所有消息通知相关的后端功能实现。该系统既需要与文章系统、订单系统、会员系统等相关联,也需要和其它业务系统相关联,是一个偏底层的通用服务系统。
【解决方案】Java 互联网项目中消息通知系统的设计与实现(下) 【解决方案】Java 互联网项目中消息通知系统的设计与实现(下)