Register now to learn Fabric in free live sessions led by the best Microsoft experts. From Apr 16 to May 9, in English and Spanish.
Hey All,
Any idea if that is possible OOTB?
Or any way to achieve that?
I have a table with IDs that appear a few times. I wold like to paint the row(s) in a table visualisation for each group of IDs. Just for the view be more user friendly.
For example
Cheers!
A
Solved! Go to Solution.
@Anonymous Man, this one does not want to give in!
I am guessing you have filters from other tables flowing into your visual which I think is causing the problem. I have updated the measure and as far as I can tell it is working with all scenarios.
Fomatting Measure = VAR CurrentID = SELECTEDVALUE(Table1[ID]) VAR FilteredCount = CALCULATE( COUNTROWS ( FILTER ( VALUES(Table1[ID]), Table1[ID] > CurrentID ) ),ALLSELECTED() ) + 1 VAR FilterTrap = COUNTROWS(VALUES(Table1[ID])) RETURN IF ( NOT ISBLANK( FilterTrap ), IF ( ISINSCOPE(Table1[ID]), IF ( ISODD ( FilteredCount ), "#7195BE", "#68CCE4" ) ) )
Sample file here: https://www.dropbox.com/s/y230n9u0wo08wjp/IDFormatting.pbix?dl=0
Here is a view with filters applied from both the table itself and from a related date table and it still works.
A calculated column is not an option because the calc is static and if you filtered out an even row but left the two odd rows on either side the calculated column would not update to change the coloring. Our measure will since it is a count based on the visable IDs.
You could write a measure to look at the ID value and format one way for odd and another way for even based on that measure using conditional formatting.
TestMeasure = VAR FormatBaseOn = SELECTEDVALUE ( 'Table'[ID] ) RETURN IF ( ISODD ( FormatBaseOn ),1 ,2 )
Are your ID's consistent enough for that to work?
Hi @Anonymous ,
Being a table visual and assuming that you have the ID column as you present it on the image do the following:
ID CHECK = IF( ISEVEN(SELECTEDVALUE(Table1[ID])) = TRUE();1;0)
Now do the condittional formatting on your columns based on this measure:
Regards,
MFelix
Regards
Miguel Félix
Proud to be a Super User!
Check out my blog: Power BI em PortuguêsHey @MFelix @jdbuchanan71
Thanks for the replies.
The ID was just to illustrate the data.
The IDs, real look like random strings. For example:
5f239534-5011-6j6b-e9bb-5b2686c1fa61 |
ea470a28-a413-d5j0-a6f4-5b26e67789ab |
etc.
Thanks
A
Hello @Anonymous
You could add a column to your table that has the ID which would count the number of ID's that are > the current ID then use that count as an odd / even switch to base the formatting on.
FormattingColumn = VAR CurrentID = Table1[ID] VAR IDCount = COUNTROWS( FILTER ( ALL ( Table1[ID] ), Table1[ID] > CurrentID) ) + 1 Return IF( ISODD ( IDCount ) , 1, 2 )
@jdbuchanan71
EDIT:
Sorry, not working well as I thought.
Maybe I am missing something?
For example (Table sorted by ID)
Amazing!
Can you please explain the logic behind the DAX?
Reading it again and again for the last 10 minutes, and not sure I understand it completely.
Understood the basic logic of counting the rows until current row, but want a more technical explanation, if possible.
Thanks a lot,
A
@Anonymous , lets try something a bit more dynamic.
Add a measure to your model that we will use to apply the formatting.
Fomatting Measure = VAR CurrentID = SELECTEDVALUE(Table1[ID]) VAR FilteredCount = CALCULATE( COUNTROWS ( FILTER ( VALUES(Table1[ID]), Table1[ID] > CurrentID ) ),ALLSELECTED() ) RETURN IF ( ISINSCOPE(Table1[ID]), IF ( ISODD ( FilteredCount ), "#7195BE", "#68CCE4" ) )
The colors we are using are listed in the measure, then we apply the formatting based on the value of the measure:
Hey @jdbuchanan71
Not sure how you are doing it. I am not able to format according to a measure. Only a column.
So I am back to square 1 again.
I tried to put your DAX in a column, but it returns empty.
Cheers,
A
@Anonymous , That is very strange. I have uploaded a copy of my testing file here. Does the formatting work in this file for you?
https://www.dropbox.com/s/y230n9u0wo08wjp/IDFormatting.pbix?dl=0
Perhaps you need to update your PowerBI desktop app?
The file also includes the formatting calc as a column in the table if you need it.
Yes, strange. Restarted my machine... the ultimate solution.
Anyhow, I am getting the same results with the measure.
Different consecutive IDs are getting the same color code.
Table is sorted by IDs.
Thanks!
A
@Anonymous Man, this one does not want to give in!
I am guessing you have filters from other tables flowing into your visual which I think is causing the problem. I have updated the measure and as far as I can tell it is working with all scenarios.
Fomatting Measure = VAR CurrentID = SELECTEDVALUE(Table1[ID]) VAR FilteredCount = CALCULATE( COUNTROWS ( FILTER ( VALUES(Table1[ID]), Table1[ID] > CurrentID ) ),ALLSELECTED() ) + 1 VAR FilterTrap = COUNTROWS(VALUES(Table1[ID])) RETURN IF ( NOT ISBLANK( FilterTrap ), IF ( ISINSCOPE(Table1[ID]), IF ( ISODD ( FilteredCount ), "#7195BE", "#68CCE4" ) ) )
Sample file here: https://www.dropbox.com/s/y230n9u0wo08wjp/IDFormatting.pbix?dl=0
Here is a view with filters applied from both the table itself and from a related date table and it still works.
A calculated column is not an option because the calc is static and if you filtered out an even row but left the two odd rows on either side the calculated column would not update to change the coloring. Our measure will since it is a count based on the visable IDs.
Hey @jdbuchanan71
Looks good at first sight.
Will test it a bit before openning the champagne.
I'll update soon...
Cheers mate!
A
COUNTROWS works over a table.
FILTER returns a table
Our filter returns a table of ALL ID's that are > the current ID, then we count that. We add 1 because if we don't, on the highest ID it returns a blank.
We then turn the count into a 1 / 2 based on even or odd.
If you want to see the steps working you can change the Return statement in the formula.
FormattingColumn = VAR CurrentID = Table1[ID] VAR IDCount = COUNTROWS( FILTER ( ALL ( Table1[ID] ), Table1[ID] > CurrentID) ) + 1 --Return IF( ISODD ( IDCount ) , 1, 2 ) Return IDCount
In the code above I commented out the switch and returned the IDCount variable instead.
Covering the world! 9:00-10:30 AM Sydney, 4:00-5:30 PM CET (Paris/Berlin), 7:00-8:30 PM Mexico City
Check out the April 2024 Power BI update to learn about new features.
User | Count |
---|---|
107 | |
99 | |
76 | |
64 | |
58 |
User | Count |
---|---|
148 | |
113 | |
97 | |
84 | |
67 |