Have you ever had the need to create a KPI that represents the # of *dimension* that represents the X% of a *measure*. For example:
- Number of customers that represents the 80% of sales
- Number of products that represent 50% of profit
- Number of countries that represent 90% of the quantity of products sold
This happened to a coworker of mine and thanks to our collective input we managed to get to a solution. In this blog, I will show you how to hack your way through Tableau to achieve this.
Let’s start creating our KPI!
Let’s take Sample Superstore and let’s try to answer: what is the number of customers that represents 80% of sales?
Just to visualise, let’s start by seeing a descending list of all the customers with their respective sales
data:image/s3,"s3://crabby-images/125f9/125f9af9a85d2995e1c675d34ac53c7ad652ca7b" alt=""
First, we will like to know what percentage the customers represent from the total sales. For that, we will do the following:
data:image/s3,"s3://crabby-images/8260b/8260b85db217b33c34791e9787db47dea21c7f00" alt=""
If you do a running sum of the sales per customer and divide it by the total amount of sales you will have a list of customers and how much their sales represent (%) from the total amount of sales.
data:image/s3,"s3://crabby-images/8e1eb/8e1ebf18011e31a21bb00fa1e57fe0d567a0f516" alt=""
Now we will want to count how many of these customers represent our 80%:
data:image/s3,"s3://crabby-images/a2231/a2231962628b8922614a92736ca8ff918ac28d84" alt=""
Your [Count] list will have a list of 1’s until your [Running Percentage] surpasses 80%.
data:image/s3,"s3://crabby-images/f0964/f09648b6a1a51babfeab7030e28da7da43a697a2" alt=""
Now what you have to do is do a running sum of this count and you will have (by the end of the list) the number you have been looking for.
data:image/s3,"s3://crabby-images/4fd48/4fd48ca5f73dd118f9001d3b6d0757661ec27755" alt=""
In this case 395 customers
data:image/s3,"s3://crabby-images/d2d24/d2d24825d9688bcf4afbb460e5499d368b61649b" alt=""
To convert this number to a KPI you will need to remove all of your measures but the last one, [Running Sum of Count]. You will also create a [LAST filter].
data:image/s3,"s3://crabby-images/1ecd8/1ecd87415e37992c2a7b74b15cd624d02095fc9d" alt=""
data:image/s3,"s3://crabby-images/36ba8/36ba860b121db01e384aa777308433d9a074105f" alt=""
Add this (True) [LAST filter] to the view and you will have a first glance of your KPI
data:image/s3,"s3://crabby-images/1caa0/1caa0947b67953adc71623dc0492ce985f3e2389" alt=""
Right-click on [Customer Name] to remove the tick of ‘Show Header’. Change or hide your title and format your view to get the KPI that you need.
data:image/s3,"s3://crabby-images/4b594/4b59476e347bca3062e3ee59017bfe682e219675" alt=""
TL;DR
data:image/s3,"s3://crabby-images/b350d/b350db2da0915c70fe75baf7abfeab1700122404" alt=""
Now you have all the tools necessary to create the KPI that you need if you follow the same principle adding your custom measures/dimensions!
For this and more tips visit our website: https://www.theinformationlab.nl/en/blogs/