Power Query: Equal Split Part 5
7 February 2024
Welcome to our Power Query blog. Today, I continue to modify the solution to divide amounts over rows by using a parameter.
In this mini-series of blogs, I have been looking at an issue that Mary, my top imaginary salesperson had. She had some accounting data, which she needed to split equally for two suppliers:
data:image/s3,"s3://crabby-images/5dd62/5dd62627fd97ea551c2454bbae95fb87e0c4c57a" alt=""
In Part 1, I created two queries:
data:image/s3,"s3://crabby-images/edf0f/edf0fa5e6d0f6f0e16293d59136e42f6588a579a" alt=""
I looked at a simple way to achieve the result I want, which assumes that I always have two [2] suppliers.
data:image/s3,"s3://crabby-images/350f6/350f6dff43730adbd9f4803ef7f4091c01d0b57c" alt=""
In Part 2, I refined this solution to make it more flexible, by using a parameter for the number of suppliers:
data:image/s3,"s3://crabby-images/82e85/82e85acd20eb9d76420d7b908cd120defcc6b2a1" alt=""
In Part 3, I looked at a slightly difference scenario. I had the same accounting data, but this time, there were no suppliers to link to:
data:image/s3,"s3://crabby-images/cddb8/cddb8cd70c1d614e34853d1138340678a804d39f" alt=""
I needed to split the rows into two [2] equal parts.
data:image/s3,"s3://crabby-images/28a0f/28a0f3bc1d0e8d1762f1097405807c6de3b9415e" alt=""
However, it is often useful to make the solution more flexible. Last time, I decided to use a parameter to decide how many ways I need to split the amounts.
data:image/s3,"s3://crabby-images/5cad0/5cad024442bbdf0eee956360f2f2577a82253a97" alt=""
I have given cell G1, containing the number to split by, a defined name, Split_By. I exported this data to Power Query, and now I have a parameter to use:
I now have a parameter to use:
data:image/s3,"s3://crabby-images/cd6d4/cd6d484ba16a9b40ed3af374c2a7fd483350d2c1" alt=""
I took a reference copy of the query I created in Part 1, Accounts, as I wish to keep the original steps:
data:image/s3,"s3://crabby-images/8e51a/8e51aaae896d6ba7b46bbd0837e0d3e3b41e94a1" alt=""
I called this reference query AccountsNS_Split. I also created a helper query, Helper_Split.
data:image/s3,"s3://crabby-images/f086d/f086df6aa7624ca049ece720cf573251935543b9" alt=""
This time, I will tidy up my helper query and complete the solution.
I don’t need Column1, I only need the correct number of rows (given by the parameter Split_By) with values in Link. I select Link and choose to ‘Remove other Columns’ from the right-click menu. This gives me a table with a single column. As I am going to merge this table using Link, I change the data type to ‘Whole Number’. Since I will not be using this query for anything else, I choose to ‘Merge Queries’, which will merge my chosen data with this query:
data:image/s3,"s3://crabby-images/ab2f5/ab2f5df913018a63d093f7eee58ee51db209630c" alt=""
In the dialog, I select AccountsNS_Split, and link using the Link column and a ‘Left Outer’ join:
data:image/s3,"s3://crabby-images/c00ce/c00ceaf43cefb4af99c430808c337a8a1d540dae" alt=""
This effectively gives me (in this case) three [3] copies of AccountsNS_Split in the same table.
data:image/s3,"s3://crabby-images/3d2bd/3d2bd911546e69b57363f19f3240e69e684d9ce0" alt=""
I expand the data (not including column Link).
data:image/s3,"s3://crabby-images/ff405/ff405e350df2778ffd80e55140c680a1b1fc18aa" alt=""
This gives me the number of rows that I need, but I also need to divide Amount by Split_By. To get the M code I need, I start by selecting Amount, and then choosing to Divide on the Standard section in the Transform tab:
data:image/s3,"s3://crabby-images/96552/965527485e47e118df1ccb079b3da2dd5249cd83" alt=""
In the dialog, I choose to divide by three:
data:image/s3,"s3://crabby-images/11888/11888d5fc335a7c37fe949725c6418a5f04d8f74" alt=""
This generates the M code I need:
data:image/s3,"s3://crabby-images/b7afa/b7afa3f69dcf3d5926e1950dc847aaa1ffda34c9" alt=""
To make this dynamic, I change the original M code from:
= Table.TransformColumns(#"Expanded AccountsNS_Split", {{"Amount", each _ / 3, type number}})
to:
= Table.TransformColumns(#"Expanded AccountsNS_Split", {{"Amount", each _ / Split_By, type number}})
This doesn’t affect the output, as Split_By is currently three.
I tidy up the data by filling down the Name and Month and removing column Link. I am not concerned about the decimal places in Amount, as I will be formatting the output in Excel when I load the data to the workbook.
data:image/s3,"s3://crabby-images/641c1/641c17d98d3784a6e6e67ce15fe45240d282a0fd" alt=""
I also rename the query AccountsNS_SplitFlex. On the Excel sheet, I change the value in cell G1 to 10:
data:image/s3,"s3://crabby-images/c87c8/c87c898d18323c28cb055bfcb62ad6755763a12e" alt=""
When I refresh the query, more rows appear, and the Amount is updated appropriately:
data:image/s3,"s3://crabby-images/f5d9d/f5d9def9e1f6f97f77573eea3473ebdf99f6aa5e" alt=""
Come back next time for more ways to use Power Query!