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

Earn a 50% discount on the DP-600 certification exam by completing the Fabric 30 Days to Learn It challenge.

Reply
DevonVanDam
Helper I
Helper I

Calculate DSO (Days Sales Outstanding) dynamically

Hi all,

 

I am trying to create a dynamic DSO matrix table, but really struggeling. I have attached some dummy data which is in the same format. I also put in some results I am able to create in Excel (with slow formulas and allot of data) => but not in Power BI.

 

Should be able to create these tables based on the white data (not the grey formulas => used those to get the required answers)

 

DevonVanDam_0-1688481235197.png

 

Hopefully someone knows.

 

Thanks,

Devon

 

Data Data 

1 ACCEPTED SOLUTION
v-yiruan-msft
Community Support
Community Support

Hi @DevonVanDam ,

I created a sample pbix file(see the attachment), please check if that is what you want.

DSO = DATEDIFF('Table'[Invoice date],'Table'[Payment date],DAY)
DSO Customer = 
VAR _custinv =
    CALCULATE (
        SUM ( 'Table'[Invoice value] ),
        FILTER ( 'Table', 'Table'[Customer] = EARLIER ( 'Table'[Customer] ) )
    )
RETURN
    DIVIDE ( 'Table'[DSO], _custinv ) * 'Table'[Invoice value]
DSO Area = 
VAR _areainv =
    CALCULATE (
        SUM ( 'Table'[Invoice value] ),
        FILTER ( 'Table', 'Table'[Sales area] = EARLIER ( 'Table'[Sales area] ) )
    )
RETURN
    DIVIDE ( 'Table'[DSO], _areainv ) * 'Table'[Invoice value]
DSO Company = 
VAR _companyinv =
    CALCULATE (
        SUM ( 'Table'[Invoice value] ),
        FILTER ( 'Table', 'Table'[Company] = EARLIER ( 'Table'[Company] ) )
    )
RETURN
    DIVIDE ( 'Table'[DSO], _companyinv ) * 'Table'[Invoice value]

vyiruanmsft_0-1688626537476.png

Best Regards

Community Support Team _ Rena
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.

View solution in original post

4 REPLIES 4
DevonVanDam
Helper I
Helper I

The flex solution is:

DSO Measure =
SUMX(
    DSO,
    DSO[DSO] * DIVIDE(DSO[Invoice Value],
                          CALCULATE(SUM(DSO[Invoice Value]),
                                    ALLSELECTED(DSO)))
)
v-yiruan-msft
Community Support
Community Support

Hi @DevonVanDam ,

I created a sample pbix file(see the attachment), please check if that is what you want.

DSO = DATEDIFF('Table'[Invoice date],'Table'[Payment date],DAY)
DSO Customer = 
VAR _custinv =
    CALCULATE (
        SUM ( 'Table'[Invoice value] ),
        FILTER ( 'Table', 'Table'[Customer] = EARLIER ( 'Table'[Customer] ) )
    )
RETURN
    DIVIDE ( 'Table'[DSO], _custinv ) * 'Table'[Invoice value]
DSO Area = 
VAR _areainv =
    CALCULATE (
        SUM ( 'Table'[Invoice value] ),
        FILTER ( 'Table', 'Table'[Sales area] = EARLIER ( 'Table'[Sales area] ) )
    )
RETURN
    DIVIDE ( 'Table'[DSO], _areainv ) * 'Table'[Invoice value]
DSO Company = 
VAR _companyinv =
    CALCULATE (
        SUM ( 'Table'[Invoice value] ),
        FILTER ( 'Table', 'Table'[Company] = EARLIER ( 'Table'[Company] ) )
    )
RETURN
    DIVIDE ( 'Table'[DSO], _companyinv ) * 'Table'[Invoice value]

vyiruanmsft_0-1688626537476.png

Best Regards

Community Support Team _ Rena
If this post helps, then please consider Accept it as the solution to help the other members find it more quickly.

Hi Yiruan,

 

Thank you very much for the swift reply. Is it possible to make this a measure? If I add in it in the columns its not dynamic when I selected a different period. Sorry my bad I did not mention this specifically, I assumed this was normal to think of => my bad!!

 

Do you know?

DevonVanDam
Helper I
Helper I

Is the data correctly shared via WeTransfer (or doesn't work? - not allowed?)

Helpful resources

Announcements
LearnSurvey

Fabric certifications survey

Certification feedback opportunity for the community.