0

目前我的数据返回:

在此处输入图像描述

我需要它做的是,如果当前月份有 0,它将默认为带有数据的上个月值:

在此处输入图像描述

我知道这可以通过嵌套IF语句来完成,但是有更好的方法吗?

已更新 @TPD 建议

@TPD 建议产生的结果:

在此处输入图像描述

度量定义为:

 IF([Land Dev Alloc] = 0, CALCULATE([Land Dev Alloc],TOPN(1, CALCULATETABLE(Hyperion,FILTER(ALL(Hyperion), [Land Dev Alloc]>0)),Hyperion[DimDateID],DESC)),[Land Dev Alloc])

Hyperion衡量的主要事实表Land Dev Alloc来自哪里

4

2 回答 2

1

我不确定这是否是最好的方法,但我最近解决了一个类似的问题,假设你有一个 Date 表和一个 Value 表,并连接了一个关系:

CurrentOrLastValue:=
CALCULATE (

    -- EXTRACT VALUE FROM ROW
    FIRSTNONBLANK( 'value'[value], 1 ),

    -- FIRST ROW FROM YOUR 'VALUES' TABLE REDUCED TO THOSE BEFORE THE CURRENT CELL DATE
    -- ORDERED BY DATE DESC
    TOPN (
        1,
        CALCULATETABLE (
            'value',
            FILTER
            ( 
                ALL( 'date'[date] ), 
                'date'[date] <= MAX( 'date'[date] )
            )
        ),
        'value'[date],
        DESC
    )
)

数据表和数据透视表

数据表和数据透视表

措施

措施

关系

关系

更新以显示测量结果而非原始值

添加新的核心度量(将值加倍以显示差异):

TotalValue:=SUM('value'[value]) * 2

添加新度量以显示所需的输出:

CurrentOrLastValueMeasure:=CALCULATE (
    [TotalValue],
    TOPN(
        1,
        CALCULATETABLE(
            'value',
            FILTER(
                ALL( 'date'[date] ),
                'date'[date] <= MAX( 'date'[date] )
            )
        ),
        'value'[date],
        DESC
    )
)

数据透视表中的新度量:

在此处输入图像描述

更新以在测量返回零时显示最后一个非零值

LastNonZeroMeasure:=
IF( [TotalValue] = 0,
    CALCULATE (
        [TotalValue],
        TOPN(
            1,
            CALCULATETABLE(
                'value',
                FILTER(
                    ALL( 'value' ),
                    [TotalValue] > 0
                )
            ),
            'value'[date],
            DESC
        )
    ),
    [TotalValue]
)

TotalValue 不再翻倍。1 月 4 日的两个数据点,用于显示度量的聚合工作。

最后一个非零测量

更新以忽略单元格日期之前的日期

尝试过滤日期也...

LastNonZeroMeasure:=IF( [TotalValue] = 0,
    CALCULATE (
        [TotalValue],
        TOPN(
            1,
            CALCULATETABLE(
                'value',
                FILTER(
                    ALL( 'value' ),
                    [TotalValue] > 0
                ),
                FILTER(
                    ALL( 'date' ),
                    'date'[date] < max( 'date'[date] )
                )
            ),
            'value'[date],
            DESC
        )
    ),
    [TotalValue]
)

在此处输入图像描述

于 2018-02-20T15:09:51.903 回答
0

最终比最初想象的要简单得多:

MeasureOne BALANCE YTD:= VAR LastNoneblankDate = CALCULATE(max('Date'[DimDateID]),FILTER(ALL('Date'),'Date'[Fiscal_Year] = MAX('Date'[Fiscal_Year])),FILTER(ALL(FactTable),[MeasureOne] > 0)) return IF([MeasureOne]=0, CALCULATE([MeasureOne],FILTER(ALL('Date'),'Date'[DimDateID] = LastNoneblankDate)), [MeasureOne BASE]) 

MeasureOne 基地在哪里:

MeasureOne BASE:= VAR LastNoneblankDate = CALCULATE(max('Date'[Date]),FILTER(ALL(FactTable),[MeasureOne] > 0)) return IF(HASONEVALUE('Date'[Date]),[MeasureOne], CALCULATE([MeasureOne],FILTER(ALL('Date'),'Date'[Date] = LastNoneblankDate)))

主要问题是设置 ALL(FactTable) 而不是 jut FactTable 并使用

于 2018-02-21T16:55:19.977 回答