DAX 默认为数据的最后一个值

DAX Default to last value with data

目前我的数据returns:

我需要它做的是,如果当前月份有 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 的主要事实 table 来自

我不确定这是否是最好的方法,但我最近解决了一个类似的问题,假设你有一个日期 table 和一个值 table 加入了一个关系:

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
    )
)

数据 table 和数据透视表 Table

测量

关系

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

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

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

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

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

枢轴中的新度量 table:

更新以显示最后 NON-ZERO 测量时的值 RETURNS 零

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]
)

结果比原先想象的要简单得多:

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 并使用

处理案例