创建列以根据实际表对行进行分类DAX PowerBI

耶尔·霍克斯特拉(Jelle Hoekstra)

我简化了要解决的问题。假设我有三个表。可以说是一种包含数据和识别对象的特定代码的苹果。

+-------------+------------+-----------+
| Data picked | Color code | Size code |
+-------------+------------+-----------+
| 1-8-2018    |          1 |         1 |
| 1-8-2018    |          1 |         3 |
| 1-8-2018    |          2 |         2 |
| 1-8-2018    |          2 |         3 |
| 1-8-2018    |          2 |         2 |
| 1-8-2018    |          3 |         3 |
| 1-8-2018    |          4 |         1 |
| 1-8-2018    |          4 |         1 |
| 1-8-2018    |          5 |         3 |
| 1-8-2018    |          6 |         1 |
| 1-8-2018    |          6 |         2 |
| 1-8-2018    |          6 |         2 |
+-------------+------------+-----------+

我有两个相关的帮助表来帮助理解代码(由于与实际情况下的其他表存在歧义,因此它们的关系在模型中处于非活动状态)。

+-----------+--------+
| Size code |  Size  |
+-----------+--------+
|         1 | Small  |
|         2 | Medium |
|         3 | Large  |
+-----------+--------+

+------------+----------------+-------+
| Color code | Color specific | Color |
+------------+----------------+-------+
|          1 | Light green    | Green |
|          2 | Green          | Green |
|          3 | Semi green     | Green |
|          4 | Red            | Red   |
|          5 | Dark           | Red   |
|          6 | Pink           | Red   |
+------------+----------------+-------+

假设我要在原始表中创建一个额外的列,以确定哪个苹果是A类和B类,因为中等绿色的苹果是A类,大的红色苹果是B类,其他苹果则保持空白,如下例所示。

+-------------+------------+-----------+-------+
| Data picked | Color code | Size code | Class |
+-------------+------------+-----------+-------+
| 1-8-2018    |          1 |         1 |       |
| 1-8-2018    |          1 |         3 |       |
| 1-8-2018    |          2 |         2 | A     |
| 1-8-2018    |          2 |         3 |       |
| 1-8-2018    |          2 |         2 | A     |
| 1-8-2018    |          3 |         3 |       |
| 1-8-2018    |          4 |         1 |       |
| 1-8-2018    |          4 |         1 |       |
| 1-8-2018    |          5 |         3 | B     |
| 1-8-2018    |          6 |         1 |       |
| 1-8-2018    |          6 |         2 |       |
| 1-8-2018    |          6 |         2 |       |
+-------------+------------+-----------+-------+

给定这些关系最初是不活动的,应该使用什么适当的DAX。最好是可解决的,而不在任何表中创建任何其他附加列。我已经尝试过类似的代码:

CALCULATE ( 
    "A" ; 
    FILTER ( 'Size Table' ; 'Size Table'[Size] = "Medium");
    FILTER ( 'Color Table' ; 'Color Table'[Color] = "Green")
)

在相同的原理上有很多变化

亚历克西斯·奥尔森(Alexis Olson)

鉴于这些关系是无效的,我建议使用LOOKUPVALUE来匹配其他表上的ID值。您应该能够创建一个计算列,如下所示:

Class = 
    VAR Size = LOOKUPVALUE('Size Table'[Size],
                   'Size Table'[Size code], 'Data Table'[Size code])
    VAR Color = LOOKUPVALUE('Color Table'[Color],
                   'Color Table'[Color code], 'Data Table'[Color code])
    RETURN SWITCH(TRUE(),
               (Size = "Medium") && (Color = "Green"), "A",
               (Size = "Large") && (Color = "Red"), "B", BLANK())

如果您的关系处于活动状态,则不需要查找:

Class = SWITCH(TRUE(),
            (RELATED('Size Table'[Size]) = "Medium") &&
            (RELATED('Color Table'[Color]) = "Green"),
            "A",
            (RELATED('Size Table'[Size]) = "Large") &&
            (RELATED('Color Table'[Color]) = "Red"),
            "B", 
            BLANK())

或者写得更优雅一些(尤其是针对更多的课程):

Class = 
    VAR SizeColor = RELATED('Size Table'[Size]) & " " & RELATED('Color Table'[Color])
    RETURN SWITCH(TRUE(),
               SizeColor = "Medium Green", "A",
               SizeColor = "Large Red", "B",
               BLANK())

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章

TOP 榜单

  1. 1

    来自Microsoft Office加载项taskpane.js的MySQL驱动程序模块的空引用

  2. 2

    使用AWS Cognito和React的仅限Facebook / Google的登录名(无用户名/密码)

  3. 3

    创建Windows Phone 8应用并将其连接到数据库的最佳方法(最好是SQL Server)

  4. 4

    为什么Java中的System.out.println()打印到控制台?

  5. 5

    卷曲函数无法解析来自bash中变量的代理

  6. 6

    是什么在Android的consumer-rules.pro和proguard-rules.pro之间的区别?

  7. 7

    设置与Apache POI Excel表散点图标记图标的颜色

  8. 8

    将Qt Pyside2与asyncio await语法一起使用?

  9. 9

    崇高的文字+蟒蛇的蟒蛇

  10. 10

    任务':app:minifyReleaseWithR8'.java.lang.NullPointerException的执行失败(无错误消息)

  11. 11

    OpenJDK的和AdoptOpenJDK的区别

  12. 12

    大型数据集缓存到Spark内存中时,“超出了GC开销限制”(通过sparklyr和RStudio)

  13. 13

    “执行测试CMAKE_HAVE_LIBC_PTHREAD”失败实际上是什么意思?

  14. 14

    使用Core 2.2中的Identity,如何在关闭浏览器15分钟后保持会话活动?

  15. 15

    React中的ForwardRefExoticComponent和ForwardRefRenderFunction有什么区别?

  16. 16

    猫鼬查找结果,然后将字段替换为findOne

  17. 17

    如何降级Google Colab的Torch版本

  18. 18

    Keras提前停止回调错误,val_loss指标不可用

  19. 19

    如何避免VSCode中的“导入路径不能以.ts扩展名结尾”错误?

  20. 20

    Nuxt.JS:如何在页面中获取路由URL参数

  21. 21

    是否有为什么会AccessibilityManager.sInstance导致内存泄漏的一个原因?

热门标签

归档