Power Query: Tidier Totals by Type
21 July 2021
Welcome to our Power Query blog. This week, I take another look at selective running totals.
Last time, I extracted running totals by Tent Type for my tent data:
data:image/s3,"s3://crabby-images/0d985/0d9859e3722697853afce4a970262d94771565f1" alt=""
Although I got to my required output, I had to make an assumption that I had seven [7] rows for each Tent Type (since I had seven months of data).
data:image/s3,"s3://crabby-images/cacc7/cacc7111b4b1faf315ad409045f716a67d83a382" alt=""
I will start from the Added Index step that I used last time.
data:image/s3,"s3://crabby-images/86d8a/86d8a5167e1f3acb8abd17f321d29767aa1a9a7d" alt=""
Since I am going to be reading the data in the table, I buffer it in step Custom1.
= Table.Buffer(#"Added Index")
The Custom Column I am going to create this time is a little more complicated, and is based upon Table() functionality instead of List() functionality. This allows me to enter conditions.
data:image/s3,"s3://crabby-images/e1717/e1717be83dcbc61cbcb5e0cece4a537320e9b6c7" alt=""
The M code I have used is:
= (Other_Table) =>Table.SelectRows(Custom1,
(Total_Table) => Total_Table[Index] <= Other_Table[Index]
and Total_Table[Tent Type] = Other_Table[Tent Type])
This looks complicated, but it can be broken down. Custom1 is the table from the previous step. Total_Table is the data that I am grouping. It’s essentially looking for all the rows where the Tent Type matches, and the Index is less than or equal to where we are now. Other_Table is the current table. The result will be a mini table, with all the rows that should be included in the running total.
data:image/s3,"s3://crabby-images/99bd9/99bd91913bf06da58497267c5b828fc840e34491" alt=""
I have grouped the data by type into these mini tables. Now I can expand them to get at the amounts.
data:image/s3,"s3://crabby-images/9677b/9677b2d5d19e743a534c4edddeb561de9bef36cf" alt=""
This gives me a subgroup for each occurrence of Tent Type containing the amounts I need to total for the running total.
data:image/s3,"s3://crabby-images/1c023/1c023ae19d2f3a3ac2318f8e17a0fdfddcace51b" alt=""
I can group these by Index.
data:image/s3,"s3://crabby-images/0d07a/0d07ababb44dfd037bd2fc458dfabdcb90e77380" alt=""
Since the values in Month, Tent Type and Amount are the same for all occurrences in the group, I use Max (I could also use Min).
data:image/s3,"s3://crabby-images/f8857/f88575fb6d22b94b06fc76d807484303c4a89081" alt=""
The results are the same as last week, but this time I didn’t need to assume anything about my data, so this query would cope with additional months being added.
Come back next time for more ways to use Power Query!