Power Query: Arranging a List
28 April 2021
Welcome to our Power Query blog. This week, I look at how to translate a range of data contained in one cell to a list of cells.
Yet again, I have some data from my imaginary salespeople:
data:image/s3,"s3://crabby-images/11f1b/11f1b630f8e96d87396a6a2151351e05e9d14a9b" alt=""
I had asked for their diary of supplier contacts, but I have instead received a list of date ranges for each salesperson and supplier. I want to have a row for each date. I start by extracting my data to Power Query using ‘From Table / Range’ on the ‘Get & Transform Data’ section of the Data tab (as usual!).
data:image/s3,"s3://crabby-images/a4c29/a4c29e02053551e0405fbaf1265628c94f449074" alt=""
I take the default range provided in the ‘Create Table’ dialog and indicate that my data has headers.
data:image/s3,"s3://crabby-images/554e2/554e213f291d8a5d7dd8db8f5c71f3a8ced47103" alt=""
Ultimately, I want to have a row for each date in the range. The steps I need to take in order to achieve this are:
- Create columns for the start and end date
- Ensure that the columns have data type date
- Create a list of all dates between the start and end date
- Ensure that this list is attached to the correct sales data.
In order to create the start and end date columns, I need to split Date Range by delimiter, which I can do from the Home tab.
data:image/s3,"s3://crabby-images/bb16c/bb16c05dab57a7f0aff5e6d57a33c805f2769bf7" alt=""
The delimiter I want to use is the dash (‘-‘).
data:image/s3,"s3://crabby-images/fb9ca/fb9ca6efbd9ae909bd1730e0c380d471d1b19af0" alt=""
This gives me two columns which I rename Start Date and End Date for clarity.
data:image/s3,"s3://crabby-images/c4afa/c4afae92ba9074d102e4335f11b2ea5d67dae362" alt=""
The next step is to set these columns to data type ‘Date’. I can do this in several places; I choose to select both columns and then right-click, where I can ‘Change Type’ to Date.
data:image/s3,"s3://crabby-images/61cb6/61cb6851cf896b2372701b16438c76e3ee4c782d" alt=""
I’m hoping this copes with all the date formats used by my salespeople.
data:image/s3,"s3://crabby-images/2f976/2f976c93fc3e10c6736c48d3d2034a505e0157f2" alt=""
Unfortunately, this is not the case. Only the dates using a forward slash (‘/’) have been correctly converted. As I did in Power Query: Dating Options, I need to convert the columns to the format that is not being correctly formatted. I need to remove the delimiters.
data:image/s3,"s3://crabby-images/7022c/7022c1ef581c94829ad7027a7a6f8bb4f38be06f" alt=""
I delete the ‘Changed Type2’ step and remove all the delimiters. Next, I have to create a custom column from the ‘Add Column’ tab where I put the delimiters into each date. Although the year length varies, I am only concerned with putting a forward slash after the second and fourth characters.
data:image/s3,"s3://crabby-images/0f6fc/0f6fc8f70ea545ec577848d62493a75cdd8dff62" alt=""
The M code I have used is:
= Text.Combine({Text.Start([Start Date],2),"/",Text.Middle([Start Date],2,2),"/",Text.Middle([Start Date],4)})
This takes the first two characters, adds a forward slash, then adds the net two characters, adds another slash, and then adds the remaining text. Finally, the elements are combined into one text string.
data:image/s3,"s3://crabby-images/f0d67/f0d6730af477b344c48514512716ce34794c1b94" alt=""
I repeat the process for the end date. Note that if there is a space at the beginning of End Date, the positions will have to be adjusted accordingly. I can then delete my original date columns and rename my new columns Start Date and End Date.
data:image/s3,"s3://crabby-images/cceec/cceec8d2ea674a76b707358e77a9cb3a5e7c23f0" alt=""
I should now be able to change the data type to ‘Date’ on my new columns.
data:image/s3,"s3://crabby-images/50cf7/50cf78058a67b4b94cd7f73646a5ed03e0ec518a" alt=""
Step 2 is complete, now I need to create a new custom column which will contain all the dates in the range. For this, I am going back to basic list creation, where I can use the ellipsis (..) to fill in the missing dates. For more on creating lists, see Power Query: Birthday Lists.
Having checked my dates are valid, I need to convert the columns to be whole numbers. This will allow me to create the list, as the ellipsis will not currently work with dates. It’s important to add a new ‘Change Type’ step for this, as I wouldn’t have been able to create a whole number from the text value with forward slashes in it.
data:image/s3,"s3://crabby-images/5af4c/5af4cff273859ad5496a567383aab8929664d5e8" alt=""
I can now add a new custom column to create the list.
data:image/s3,"s3://crabby-images/1bcdd/1bcdd5f55dec056e8d0b484660f3c46dba502c8d" alt=""
The M code I have used is:
= {[Start Date]..[End Date]}
This creates a list of numbers from Start Date to End Date, which I will be able to convert back to dates.
data:image/s3,"s3://crabby-images/07ceb/07ceb148f46b3cc95d934114b41dc947eda42dde" alt=""
I can see that the list contains the values; now I can move to step 4, which is to expand my column.
data:image/s3,"s3://crabby-images/e513b/e513bb64d908890d081cad7b032a21de5f65ce9c" alt=""
I choose to ‘Expand to New Rows’.
data:image/s3,"s3://crabby-images/86455/86455489e76f7c0b461f1556144fd340704de12a" alt=""
I have a row for each day. Now, I need to delete Start Date and End Date and convert Dates List to a date.
data:image/s3,"s3://crabby-images/83cf2/83cf220a72f636c1d8e4b6d233c5976f44dd4e78" alt=""
I can see that I have a row for each date with all the relevant data.
Come back next time for more ways to use Power Query!