Power Query: Totals by Type
14 July 2021
Welcome to our Power Query blog. This week I look at selective running totals.
I have some tent data (yet again).
data:image/s3,"s3://crabby-images/83364/83364f7561b8815c481f12f2e857323c3febd860" alt=""
I am going to create some running totals. I start by loading my data to Power Query using ‘From Table/Range’ from the ‘Get & Transform Data’ section of the Data tab.
data:image/s3,"s3://crabby-images/f8822/f88222e1c9b625b978fe0111ceeeb0e647088188" alt=""
I take the defaults and load my data.
data:image/s3,"s3://crabby-images/9d034/9d0349ca2ea98870eac0285ddeb2ac254657e0de" alt=""
I will start by creating a running total using List() functionality, as I did in Power Query: Keep On Running. To achieve this, I start by adding an Index column from the ‘Add Column’ tab.
data:image/s3,"s3://crabby-images/75beb/75beb5d17b3b6131b65d4b84b7dc68423c5ffbba" alt=""
I’ll start from one [1].
data:image/s3,"s3://crabby-images/97f1c/97f1c10bd148b31dc143bab6cf9c9e16c23c89a9" alt=""
Now, I can create a Custom Column to calculate the running total.
data:image/s3,"s3://crabby-images/b8da2/b8da2e8fc52490b8c462c2e5ff01c0fff5e0bdcb" alt=""
This gives me the running total.
data:image/s3,"s3://crabby-images/f20c7/f20c7180a470e99cd8b081bfecea67a6b9c0b8d4" alt=""
I can then add list buffering to stop it from reading the list of amounts every time it calculates a running total field.
data:image/s3,"s3://crabby-images/e7fd5/e7fd52a9b4f638e146a14abbad5095db01f8ad95" alt=""
However, now I want to see the running total for each Tent Type. The method I will use this week is specific to this dataset. I will look at a more generic method next week.
I start from the Added Index step. I need to sort my data by Tent Type and then by Index.
data:image/s3,"s3://crabby-images/d1667/d166764a51cfe037eefb2ac0f040a6151becd563" alt=""
Having done both sorts, my data is ready for the next step.
data:image/s3,"s3://crabby-images/98bb4/98bb476bfd91237f04b3f2f8d1e2ee2572da21d0" alt=""
I am going to use similar M code to the overall running total, which was:
= List.Sum(List.Range(#"Buffered List",0, [Index])))
However, this time I want the values in [Index] to only increment within each Tent Type, and instead of using an offset of zero, I will offset to read the values for each Tent Type.
I start by creating a new Index column from the ‘Add Column’ tab.
data:image/s3,"s3://crabby-images/7f522/7f5225a5a34c52a3f8d4c0282421da640e309dcf" alt=""
Next, I set up the column I will be using as the offset in my calculation. From the ‘Add Column’ tab, I insert a column which is Index.1 divided by seven [7].
data:image/s3,"s3://crabby-images/bfd9b/bfd9b7918ffc8521341869c52f67ad947eec1db2" alt=""
I just need to tidy up these columns now. Using the Transform tab, I apply modulo seven [7] to Index.1, and add one [1] to it. I also round down Division.
data:image/s3,"s3://crabby-images/22789/22789f54ce860134954a5167bea1896e76d3167f" alt=""
Now I am ready to apply the list functions to get my running totals.
data:image/s3,"s3://crabby-images/64718/64718241dc2402f2ea2c7058b4e24b995d7c8931" alt=""
The M code I have used is:
= List.Sum(List.Range(#"Added to Column"[Amount],[Division]*7,[Index.1]))
I am summing up the amounts for my data in groups of seven [7].
data:image/s3,"s3://crabby-images/0d50f/0d50f25a4d3bcd3ed7f7e1875a58e9ac5a46a767" alt=""
The amounts are correct. I can sort by the original Index to restore the order and remove the columns I used to work towards the result.
data:image/s3,"s3://crabby-images/67bc5/67bc518add91d4291f2ee230ff947682f2b69d26" alt=""
Next time I will look at another method, which doesn’t rely on the data being in groups of seven [7].
Come back next time for more ways to use Power Query!