Power Query: Part Time
27 January 2021
Welcome to our Power Query blog. This week, I look at adding rows to existing data in order to present a complete picture.
I have some data for parts for my imaginary tent business.
data:image/s3,"s3://crabby-images/832af/832af94646ccb3e33297179fa7a639c91544023b" alt=""
It shows me how many parts of a particular type that were required, but there are no rows if the parts required were zero. I want to have a row for each part and date combination, even if the required quantity was zero.
To do this, I begin by uploading my data to Power Query. I use ‘From Table’ on the ‘Get & Transform’ section of the Data tab.
data:image/s3,"s3://crabby-images/a489b/a489b9832b62b3271de45b0295dcad0e45d8c319" alt=""
I accept the defaults for the ‘Create Table’ dialog.
data:image/s3,"s3://crabby-images/17e69/17e6906f65f9f6162a6f567c8b78b2e70002ecf8" alt=""
I want to view my data in date order, so I sort on the Date column.
data:image/s3,"s3://crabby-images/bf738/bf738723e827b656d50588de66515a7a385b76f5" alt=""
I can do this by selecting the Date column and using the icon next to the title. I choose to ‘Sort Ascending’.
data:image/s3,"s3://crabby-images/1090a/1090a7506bc510380cd1e7f934a2359fc03f0251" alt=""
I then do the same thing for Part Number.
data:image/s3,"s3://crabby-images/525d4/525d4f9ca8b41bdb2ea28f25207ae9c7ed901084" alt=""
I would like to generate rows for the part numbers to show when there was no demand. There are a number of ways to do this, but I will create a query to link to. This new query will be a matrix, linking all dates to all part numbers in my query.
data:image/s3,"s3://crabby-images/57c1c/57c1c96dfbfed87068cf04c564b59460921c606d" alt=""
I create a new query just for the Date column.
data:image/s3,"s3://crabby-images/7283e/7283ecfa45641077b9863e0b615da39cab44e086" alt=""
I then choose to remove duplicates, so that I have a list of unique dates.
data:image/s3,"s3://crabby-images/efea2/efea2b1b18b6a52772f3c303906ae06f1e069a64" alt=""
I go back to the original query and do the same for Part Number.
data:image/s3,"s3://crabby-images/670d6/670d663fd9077724aa4446f8cb61bce020933fe8" alt=""
I want to combine my two new queries, so I convert Part Number to a table. I will add the data from the list query Date to my Part Number table.
data:image/s3,"s3://crabby-images/1eca6/1eca6b444c3c37788afb11b1c443bf3e753f6c2b" alt=""
On the ‘Add Column’ tab, I choose to add a custom column. In the formula box for this column, I enter the list query Date.
data:image/s3,"s3://crabby-images/68487/6848704be6709ea2ab7b2fd9024e82ee465fafb0" alt=""
This creates a new column where each value is a list. If I click in the space next to each list, I can see the contents. I need to expand the list.
data:image/s3,"s3://crabby-images/7ee46/7ee462946c3ae46538eecceade20748c2164e7cd" alt=""
I choose to expand to new rows, as my aim is to create a matrix where each date links to each part number.
data:image/s3,"s3://crabby-images/cf3a2/cf3a2742c76597f3b8661bdba0987534eb34f6a4" alt=""
I have my matrix, and for clarity, I rename my columns and change the data type of Date to date / time. I can link this matrix query to my original query, to fill in the values that I have for Quantity Required.
data:image/s3,"s3://crabby-images/84279/84279e88630f5d6bc8bb9516e53df82e45ccfe91" alt=""
From the Home tab, I select ‘Merge Queries’. I choose to merge this with my original query and link on Part Number and Date. I choose a left outer join.
data:image/s3,"s3://crabby-images/8a27f/8a27fbb1fb356c6752e8d0cb7ddd4d810237ddea" alt=""
I need to expand the new column; I will only need the quantity column.
data:image/s3,"s3://crabby-images/47afc/47afca45f75ddfa37eec63271af89f18447118ac" alt=""
I choose to only extract Quantity Required, and to keep that column name.
data:image/s3,"s3://crabby-images/a87e0/a87e09029d9a166e106ca357d3d1121f80564a49" alt=""
I want to show all the null values as zeroes.
data:image/s3,"s3://crabby-images/f8b01/f8b011ccd8eff8c83b742f552fe9162d88f1fef7" alt=""
I right click on Quantity Required and choose to ‘Replace Values’. I opt to replace null with zero [0].
data:image/s3,"s3://crabby-images/5e476/5e476619972f6cdb7876fc13b9fff830be047f62" alt=""
I reorder my columns and sort on Date and then Part Number. I have my data in the required format at long last!
Come back next time for more ways to use Power Query!