Power Query: Reorganising by Numbers
18 March 2020
Welcome to our Power Query blog. This week, I look at using some numerical functions to sort out expense formatting.
I have more expense data from my imaginary salespeople. I need to format it so that I have my data in separate columns.
data:image/s3,"s3://crabby-images/7ad5f/7ad5fb5a6faca221e90064acbf4b8155e6637cc3" alt=""
As usual, my first step is to extract the data to Power Query, using the ‘From Table’ option in the ‘Get & Transform’ section of the Data tab.
data:image/s3,"s3://crabby-images/b0423/b0423941666ef686a720f9b3513a9fe23fab2ce1" alt=""
The first thing I notice is that Power Query has generated a ‘Changed Type’ step, which sets the column type to Any. As this doesn’t achieve anything, I remove this step by clicking the X next to it.
data:image/s3,"s3://crabby-images/0e5cf/0e5cf46d78bde38360487bed307b6a9c35f922f6" alt=""
I need a way of distinguishing between the rows, so I add an index from the ‘Add Column’ tab. I will start my index at zero (0).
data:image/s3,"s3://crabby-images/6e847/6e8473929e77d8596f4ce26af67ec6c65b339ba0" alt=""
Since my data is in groups of five (5) rows, I can use another feature on the ‘Add Column’ tab, which is in the Standard dropdown of ‘From Number’.
data:image/s3,"s3://crabby-images/883ee/883ee3f42f1f78068a02c554f098fbe8e65036c2" alt=""
Using ‘Integer-Divide’, I want to divide this Index column such that I retain only the integer part of the division result:
data:image/s3,"s3://crabby-images/6b901/6b9018a951791c121092a47617084575ccc99328" alt=""
I choose to divide by five (5) and click ‘OK’.
data:image/s3,"s3://crabby-images/74cd1/74cd108b11423ae0b524b663357579ffbd909f01" alt=""
I now have a column which counts my rows, and a column which identifies each group of data. I combine these by using the mod functionality. I will transform my Index column using the Modulo option in the Standard options in the ‘From Number’ section on the Transform tab.
data:image/s3,"s3://crabby-images/20d13/20d1369c4ee84913af949cc0e678abcaf02a2402" alt=""
I need to specify the value to use, which again is five (5), since that is the size of each data group.
data:image/s3,"s3://crabby-images/ef4d1/ef4d1e9cf46a2eb14a0f5df686330b0ceb86f76d" alt=""
I click ‘OK’ to see the changes to my Index column.
data:image/s3,"s3://crabby-images/5fe79/5fe79813bb7222ac759095d36891d86e52997678" alt=""
I now have each line in my data group numbered. I can use this to pivot my data. First, I move Integer Division to the first column place.
data:image/s3,"s3://crabby-images/ab495/ab495af06922b89c3d8d7c0513ec8ddc4418724c" alt=""
Second, I can select my Index column, and choose to ‘Pivot Column’ from the ‘Any Column’ section of the Transform tab.
data:image/s3,"s3://crabby-images/fd793/fd7937198cacf8a1fbda83a70ec215d7143f8099" alt=""
I want to use the values in Details, and I don’t need to aggregate them in any way.
data:image/s3,"s3://crabby-images/e8d85/e8d85919d7027708e1b1002031b7cf17d00a219f" alt=""
This is looking more promising. I just need to tidy up my data by removing excess columns and by renaming my remaining columns.
data:image/s3,"s3://crabby-images/6cd78/6cd780c6ec4ca61ee1dc8d5b36dda6c312b79d41" alt=""
My data is now in a format where I can merge it with other expense data.
Come back next time for more ways to use Power Query!