data:image/s3,"s3://crabby-images/aa42b/aa42b3f944cfc1ed34c39cd0a7e476101d32f205" alt=""
I’m going to try and share some of the techniques and methods I use as a consultant. Using Tableau & Alteryx daily means that I’ve found I take small techniques, tips & tricks for granted. Hopefully this will be useful for you all.
Speaking to someone internally recently, we we looking to set a 'ranking' set-up with Tableau to work out the top 5 of a dimension per year. In this example, I'll use Tableau's trusty Superstore Sales to demonstrate the problem, and the solution I came to.
data:image/s3,"s3://crabby-images/b30b0/b30b0d55806d18c402d40b6f77cafb261465673b" alt=""
The standard way to set a top 5 filter in Tableau is to either right-click a dimension and click 'Filter' before going to the 'Top' tab and setting the field.
data:image/s3,"s3://crabby-images/a14e1/a14e180b3774bf75fb7403d9ad7cc634f8a511c3" alt=""
While this works at a high level (that the Sum of Sales overall in the dataset has THESE 5 subcategories as the highest), as shown above. But below, we can see, this isn't answering the question we have - that we want to see the top 5 for each year.
data:image/s3,"s3://crabby-images/8a6a1/8a6a124d2816b94d23aa1966e87d172e6ac4bb9e" alt=""
Instead, we have to use an INDEX() calculation, which we will use to rank each of these, instructing Tableau that this restarts every year.
I would use RANK() or RANK_UNIQUE() here, however, having used them in the past, I don't trust them as much as INDEX(). For those who may not know, INDEX() is a Table Calculation which simply counts and assigns a number based on your rule. So by default, it will count from top to bottom 1-infinity, as below.
data:image/s3,"s3://crabby-images/738a6/738a680a1e472aea75601cace48222e363f3d57e" alt=""
What we want to do, however, is have this restart every year - by right-clicking our INDEX() calc and editing the Table Calculation in the window as below.
data:image/s3,"s3://crabby-images/d1941/d194139318da9c5c225aa9bc834132ada75e8424" alt=""
Finally, we'll filter on the top 5 using our new INDEX() field and only keep the top 5.
data:image/s3,"s3://crabby-images/ac7e4/ac7e4f5b0ef04755ed05b211ee814768350cd423" alt=""
So this solves our problem. However, what happens if I want to see two additional things:
- Swap between the full list, and the top 5
- See the Manufacturer for each Sub-Category to understand who's inside
To answer question 1 - We need to create a parameter..
data:image/s3,"s3://crabby-images/09279/09279c9daf18c50e0a00b290739ab6462024ab8e" alt=""
Then we connect this parameter to a calculated field, as below
data:image/s3,"s3://crabby-images/de45c/de45c6926c98ff682238d5276f3638d1a63be05c" alt=""
Finally, replace the INDEX() calc we had before with this new calculation, and when 'Top 5' is selected on the parameter, then make sure you 'EXCLUDE' the NULL value.
data:image/s3,"s3://crabby-images/fd71b/fd71b8f8a81a748d831169fbfc7baa6dc984f2f5" alt=""
And for our 2nd question, about Manufacturers, we want to create this sheet, ensuring we've set the sort order to be by field.
data:image/s3,"s3://crabby-images/d9feb/d9febe2c42c087c8e3af33a41309893528288b25" alt=""
And to finish off, we can put it in the main Top 5/All bar chart as a Viz in Tooltip.
data:image/s3,"s3://crabby-images/66c81/66c81a50f55feb659ea8cb88659e195372882899" alt=""
Thanks for reading!