Skip to main content
cancel
Showing results for 
Search instead for 
Did you mean: 

Get certified in Microsoft Fabric—for free! For a limited time, get a free DP-600 exam voucher to use by the end of 2024. Register now

Reply
Henrik_99
Resolver I
Resolver I

DAX Power BI Desktop

Hi,

 

I am trying to show the difference between Panned Hrs Earned Hrsided by 2 (2= 2 next weeks) per activity based on last cut off date and add this data to the next 2 weeks (e.g. 2 next cut off dates) to the corresponding activity no.

 

The below example is illustrated in the table below, which also shows the calculations. If anyone could help me out that would be great 🙂

 

Untitled.png.

 

Rgds

Henrik

2 ACCEPTED SOLUTIONS
v-sihou-msft
Microsoft Employee
Microsoft Employee

@Henrik_99

 

In this scenario, you need to get the last non blank Panned-Earned's Cut_Off_Date, have it compare with current date to determine if it should return half of the last non blank Panned-Earned. Please refer to my sample below:

 

 

LastNonBlankDate =
CALCULATE (
    MAX ( 'Table'[Cut_Off_Date] ),
    FILTER (
        'Table',
        'Table'[Cut_Off_Date] < EARLIER ( 'Table'[Cut_Off_Date] )
            && 'Table'[ID] = EARLIER ( 'Table'[ID] )
            && 'Table'[Panned-Earned] <> BLANK ()
    )
)
DateDiff = 1*('Table'[Cut_Off_Date]-'Table'[LastNonBlankDate])
Column =
IF (
    'Table'[Panned-Earned] = 0,
    IF (
        'Table'[DateDiff] <= 14,
        CALCULATE (
            LASTNONBLANK ( 'Table'[Panned-Earned], 1 ),
            FILTER (
                'Table',
                'Table'[Cut_Off_Date] < EARLIER ( 'Table'[Cut_Off_Date] )
                    && 'Table'[ID] = EARLIER ( 'Table'[ID] )
            )
        )
            / 2,
        BLANK ()
    ),
    'Table'[Panned-Earned]
)

If you just want to build one column, it can be like:

 

Column =
IF (
    'Table'[Panned-Earned] = 0,
    IF (
        1
            * (
                'Table'[Cut_Off_Date]
                    - CALCULATE (
                        MAX ( 'Table'[Cut_Off_Date] ),
                        FILTER (
                            'Table',
                            'Table'[Cut_Off_Date] < EARLIER ( 'Table'[Cut_Off_Date] )
                                && 'Table'[ID] = EARLIER ( 'Table'[ID] )
                                && 'Table'[Panned-Earned] <> BLANK ()
                        )
                    )
            )
            <= 14,
        CALCULATE (
            LASTNONBLANK ( 'Table'[Panned-Earned], 1 ),
            FILTER (
                'Table',
                'Table'[Cut_Off_Date] < EARLIER ( 'Table'[Cut_Off_Date] )
                    && 'Table'[ID] = EARLIER ( 'Table'[ID] )
            )
        )
            / 2,
        BLANK ()
    ),
    'Table'[Panned-Earned]
)

123.PNG

 

Regards,

 

View solution in original post

Hi Simon,

 

Thank you very much for your reply. I need to verify the solution in my desktop and give you a Feedback, thanks.

 

Regards

Henrik

View solution in original post

3 REPLIES 3
Henrik_99
Resolver I
Resolver I

Hi,

 

Just additional question. The soultion worked successfully for Calculated colums. What about for measures, see example below?

 

Thanks.

 

Rgds

H.

PowerBI_quest2.JPG

v-sihou-msft
Microsoft Employee
Microsoft Employee

@Henrik_99

 

In this scenario, you need to get the last non blank Panned-Earned's Cut_Off_Date, have it compare with current date to determine if it should return half of the last non blank Panned-Earned. Please refer to my sample below:

 

 

LastNonBlankDate =
CALCULATE (
    MAX ( 'Table'[Cut_Off_Date] ),
    FILTER (
        'Table',
        'Table'[Cut_Off_Date] < EARLIER ( 'Table'[Cut_Off_Date] )
            && 'Table'[ID] = EARLIER ( 'Table'[ID] )
            && 'Table'[Panned-Earned] <> BLANK ()
    )
)
DateDiff = 1*('Table'[Cut_Off_Date]-'Table'[LastNonBlankDate])
Column =
IF (
    'Table'[Panned-Earned] = 0,
    IF (
        'Table'[DateDiff] <= 14,
        CALCULATE (
            LASTNONBLANK ( 'Table'[Panned-Earned], 1 ),
            FILTER (
                'Table',
                'Table'[Cut_Off_Date] < EARLIER ( 'Table'[Cut_Off_Date] )
                    && 'Table'[ID] = EARLIER ( 'Table'[ID] )
            )
        )
            / 2,
        BLANK ()
    ),
    'Table'[Panned-Earned]
)

If you just want to build one column, it can be like:

 

Column =
IF (
    'Table'[Panned-Earned] = 0,
    IF (
        1
            * (
                'Table'[Cut_Off_Date]
                    - CALCULATE (
                        MAX ( 'Table'[Cut_Off_Date] ),
                        FILTER (
                            'Table',
                            'Table'[Cut_Off_Date] < EARLIER ( 'Table'[Cut_Off_Date] )
                                && 'Table'[ID] = EARLIER ( 'Table'[ID] )
                                && 'Table'[Panned-Earned] <> BLANK ()
                        )
                    )
            )
            <= 14,
        CALCULATE (
            LASTNONBLANK ( 'Table'[Panned-Earned], 1 ),
            FILTER (
                'Table',
                'Table'[Cut_Off_Date] < EARLIER ( 'Table'[Cut_Off_Date] )
                    && 'Table'[ID] = EARLIER ( 'Table'[ID] )
            )
        )
            / 2,
        BLANK ()
    ),
    'Table'[Panned-Earned]
)

123.PNG

 

Regards,

 

Hi Simon,

 

Thank you very much for your reply. I need to verify the solution in my desktop and give you a Feedback, thanks.

 

Regards

Henrik

Helpful resources

Announcements
November Carousel

Fabric Community Update - November 2024

Find out what's new and trending in the Fabric Community.

Live Sessions with Fabric DB

Be one of the first to start using Fabric Databases

Starting December 3, join live sessions with database experts and the Fabric product team to learn just how easy it is to get started.

Las Vegas 2025

Join us at the Microsoft Fabric Community Conference

March 31 - April 2, 2025, in Las Vegas, Nevada. Use code MSCUST for a $150 discount! Early Bird pricing ends December 9th.

Nov PBI Update Carousel

Power BI Monthly Update - November 2024

Check out the November 2024 Power BI update to learn about new features.