gpt4 book ai didi

powerbi - power bi 矩阵中的自定义聚合列

转载 作者:行者123 更新时间:2023-12-04 17:30:12 24 4
gpt4 key购买 nike

我正在尝试在 Power BI 报告中创建一个矩阵,总结以多种不同方式切片的销售人员绩效。

我知道如何使用行 - 销售人员、列 - 产品类型和值 - 销售计数创建矩阵,这将显示每种产品类型的每个销售人员的销售数量,但我还希望能够执行以下操作:

  • 添加一个附加列设置为透视(例如销售年份),以便我可以在同一个表中并排看到按产品类型和年份透视的销售额计数(即,不嵌套)。
  • 向我的矩阵添加额外的汇总列,显示诸如销售员平均销售金额、销售员销售总数百分比等值。

  • 为清楚起见,我想这会产生一个矩阵,其中列标题为:销售员、产品 1、产品 2、...、第 1 年、第 2 年、...、总销售额、平均销售额、占总销售额的百分比。请参阅下面的图片链接(我还没有包含实际图片的声誉点)

    image of example matrix

    我认识到我可以通过创建有效复制矩阵如何拆分值并将每个度量添加为值(无列)的度量来做到这一点,但我不想每次都创建新度量并更新矩阵年或每次我们添加新的产品类型时。

    我还查看了 Power BI 市场上的自定义视觉效果,但没有看到任何可以实现这一目标的视觉效果。

    最佳答案

    有可能做到这一点,但不是很容易。你需要一个带有 SWITCH 的度量以及用于标题的表格。

    您可以按照以下方式创建标题表:

    Header =
    UNION (
    SUMMARIZE ( Sales, Sales[Product], "Group", "By Product", "Index", 1 ),
    SUMMARIZE ( Sales, Sales[Year], "Group", "By Year", "Index", 2 ),
    DATATABLE (
    "Header", STRING,
    "Group", STRING,
    "Index", INTEGER,
    {
    { " Total", "Summarizations", 3 },
    { "% of Total Sales", "Summarizations", 3 },
    { "Avg Sale Size", "Summarizations", 3 }
    }
    )
    )

    看起来像这样:
    Header,            Group,          Index,
    Product 1, By Product, 1,
    Product 2, By Product, 1,
    2016, By Year, 2,
    2017, By Year, 2,
    2018, By Year, 2,
    Total, Summarizations, 3,
    % of Total Sales, Summarizations, 3,
    Avg Sale Size, Summarizations, 3

    当添加更多产品或年份时,此表将自动扩展。

    (注意: Index 列是这样我可以使用按列排序来正确排序它们。)

    一旦你有了它,你只需要输入 GroupHeader在矩阵视觉和 Salesperson 的列上在行上,在值中具有切换度量。
    Measure =
    VAR Val =
    SWITCH (
    SELECTEDVALUE ( Header[Group] ),
    "By Product", CALCULATE (
    SUM ( Sales[Amount] ),
    FILTER ( Sales, Sales[Product] = MAX ( Header[Header] ) )
    ),
    "By Year", CALCULATE (
    SUM ( Sales[Amount] ),
    FILTER ( Sales, Sales[Year] = VALUE ( MAX ( Header[Header] ) ) )
    ),
    SWITCH (
    SELECTEDVALUE ( Header[Header] ),
    "% of Total Sales", DIVIDE (
    SUM ( Sales[Amount] ),
    CALCULATE ( SUM ( Sales[Amount] ), ALL ( Sales ) )
    ),
    "Avg Sale Size", AVERAGE ( Sales[Amount] ),
    SUM ( Sales[Amount] )
    )
    )
    RETURN
    IF (
    SELECTEDVALUE ( Header[Header] ) = "% of Total Sales",
    FORMAT ( Val, "0.0%" ),
    FORMAT ( Val, "0.0" )
    )

    每个不同的组都有自己的计算,我们必须使用 FORMAT函数强制表格正确格式化百分比函数。

    (注意:如果你有切片器或过滤器,你可能想使用 ALLSELECTED,我在上面使用了 ALL。)

    这是我的表的样子(不是完全相同的数据,而是类似的结构)

    Grouped Table

    这是我为此创建的 PBIX 文件:

    https://drive.google.com/file/d/1qxc5p53MgmOm-NH3EcivkZLhLeEHpr4R/

    关于powerbi - power bi 矩阵中的自定义聚合列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52632713/

    24 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com