Power Query: Month Mayhem – Part 2
10 July 2024
Welcome to our Power Query blog. Today, I continue looking at how to index my data to keep everything in order.
My salespeople are back from their break and I have more reports to construct. I have a report with a list of the clients they have been working with each month:
data:image/s3,"s3://crabby-images/217b0/217b01ea13fe01e081204d4c5cdab6d153edd5a2" alt=""
I would like to display the amount details in the salesperson sections but aligned to the relevant month at the top of the page:
data:image/s3,"s3://crabby-images/37efe/37efebdf338475f45723bdaa0e09d05883ebd19d" alt=""
Last time, I extracted the data to a new workbook and began transforming the data, viz.
data:image/s3,"s3://crabby-images/923e9/923e94023069bb977ddf3b302b0a4d7253262980" alt=""
I created two indices, Source Full Index indicates the position of the row in the report, and Section Index will be used to keep the sub-sections together. This time, I will recombine the data, and show how this will help me to identify the data in each section.
I choose to merge my query with itself, using the ‘Merge Queries’ option on the Home tab:
data:image/s3,"s3://crabby-images/7b25b/7b25bea8d160353261009deb9a2300d51ee8a6e9" alt=""
In the dialog, I select ‘Sheet1(Current)’ to merge with the same query.
data:image/s3,"s3://crabby-images/04033/040336cd42bb6b2042304b7a404421e5152f52c9" alt=""
I select the column Source Full Index on both instances of the query and choose a ‘Left Outer’ join:
data:image/s3,"s3://crabby-images/5b638/5b638e05ae974bdc338a7cb2b6af1736e1714059" alt=""
Having created the step, I have the following M code:
= Table.NestedJoin(#"Renamed Columns1", {"Source Full Index"}, #"Renamed Columns1", {"Source Full Index"}, "Renamed Columns1", JoinKind.LeftOuter)
I want to change the first table to be the step ‘Renamed Columns’ (i.e. when I renamed the first index) instead of ‘Renamed Columns1’:
= Table.NestedJoin(#"Renamed Columns", {"Source Full Index"}, #"Renamed Columns1", {"Source Full Index"}, "Renamed Columns1", JoinKind.LeftOuter)
This gives me the following result:
data:image/s3,"s3://crabby-images/37865/378650871774b857048e4227850f67c5f553f270" alt=""
I click on the icon next to the heading in the column Renamed Columns1, and choose which data to expand:
data:image/s3,"s3://crabby-images/df534/df534b555622ec0e74f60b57f8ecbe656c36163d" alt=""
I only need the column Section Index. I also notice that my data is no longer in ascending Source Full Index order:
data:image/s3,"s3://crabby-images/d0542/d05420887f596c8fdc8d5e9d8876e78eec8b0373" alt=""
I sort ascending on Source Full Index:
data:image/s3,"s3://crabby-images/f3f32/f3f326c7e3a3815ccc98a582c4264c02332d5055" alt=""
Now I can see that the report sub-heading sections may be grouped together by filling down Section Index. I can achieve this by right-clicking on the heading of Section Index and choosing Fill and then Down:
data:image/s3,"s3://crabby-images/aa7b0/aa7b0d578bb3a8d573e98e6e293b0c6e79e23069" alt=""
I may now remove the column Source Full Index:
data:image/s3,"s3://crabby-images/9d89a/9d89af76a563053f10d8fef20a056ff796a819c4" alt=""
From this point, I need to treat the rows with amounts differently from the rest of the data. I will be using this query as a building block. I rename it to Source Data to make its purpose clearer:
data:image/s3,"s3://crabby-images/5a5fc/5a5fc0ab6f9b27f5cddd521bccc99c17a955f90a" alt=""
Next time, I will take a reference copy of Source Data and continue transforming the data.
Come back next time for more ways to use Power Query!