OK, well here is your circular dependency when you use these together:
Audits due column = CALCULATE(DISTINCTCOUNT(' Audits'[PRID]),VALUES(' Audits'[Compliance Date]))
Audits Over due Column = IF((' Audits'[Compliance Date]< ' Audits'[Date Audit Performed]) || ISBLANK(' Audits'[Date Audit Performed]) && (' Audits'[Compliance Date])< TODAY(),1,0)
So, I don't understand that if the 2 things above are columns, why are you using VALUES? Are these measures or columns in a table?
Really, some SAMPLE data would be incredibly useful. Just make some up that emulates your actual data. Would only need 2 or 3 rows.
@Greg_Deckler , I've created a sample data set, also tried to explain as i can!
Hope its clear, please let me know if you need more info! Thanks a ton 🙂
Sorry here is the link to https://www.dropbox.com/sh/w1cxxiijhn7060u/AACtywXqUK00HuAKWRP2vstYa?dl=0
|Id||Site||Compliance Date||Date Performed||Total Due||Total Overdue||% performed on time|
|5||Lellyan||13/03/2020||1||1 ( over due because not performed)||0.00%|
|7||Rome||12/03/2020||Not counted because there is no complaince date||#VALUE!|
|12||Milan||22/03/2020||22/03/2020||Not counted because the date is in future||#VALUE!|
|Total Due: Countdistint of id where compliance date is non blank and less than today (ID is unique and there can be multiple audits on same date), so need to take id into consideration for total due|
OK, I did it with these two columns:
Total Due 1 = IF(ISBLANK([Compliance Date]) || [Compliance Date] > TODAY(),BLANK(),1) Total Overdue 1 = SWITCH(TRUE(), ISBLANK([Compliance Date]),BLANK(), ISBLANK([Date Performed]) && [Compliance Date] < TODAY(),1, [Date Performed] > [Compliance Date],1, [Compliance Date]>TODAY(),BLANK(), 0 )
And this measure:
Measure = DIVIDE(COUNTROWS(FILTER('Table',NOT(ISBLANK([Total Overdue 1])) && [Total Overdue 1] = 0)),SUM('Table'[Total Due 1]))
PBIX is attached. I think you have an error in your data for Spain. Spain looks like it is overdue.
Thanks a lot Greg!! Yes you are right...Spain should be over due....!
For the total due, instead of counting it as 1, if we use distinct count of the id's, we are there...currently this is the result..because 1 audit can be done at two places with same id and we want to calculate it as 1.
i did tried calculation to replace 1 by disntict count of ID's but no luck...:( still see the same numbers..
@JCK2 - are you looking for this?
Measure 2 = DIVIDE( COUNTROWS(FILTER(FILTER('Table',DISTINCT('Table'[Id])),NOT(ISBLANK([Total Overdue 1])) && [Total Overdue 1] = 0)), SUM('Table'[Total Due 1]) )
Apologies, maybe this:
Measure 2 = DIVIDE( COUNTROWS(FILTER(SUMMARIZE('Table',[Id],"__Count",IF(NOT(ISBLANK(MAX('Table'[Total Overdue 1]))) && MAX([Total Overdue 1]) = 0,1,0)),[__Count]=1)), SUM('Table'[Total Due 1]) )
@Greg_Deckler Thanks a lot for your effort and patience, it worked :)!
I started using Powerbi from last week, always have been using Alteryx and Tableau...this was my first challange!!
Appreciate your help in onboarding and making me love PowerBi!!
Look forward to keep learning more things from you Greg!! You are a True Guru :)! Thanks once again!
We're excited to announce our first cross-community 'Can You Solve These?' challenge!
Visit our Community Blog for articles, guides, and information created by fellow community members.
Wondering what events you could join or have an event to promote yourself? Check out our Upcoming Events.
We are thrilled to announce we will begin running a monthly webinar series named Power BI Dev Camp.