Power Query: Refined Rental Wrangles
4 August 2021
Welcome to our Power Query blog. This week, I look at creating a function to get data from a table.
Last week, I was working with some data on tent rentals:
data:image/s3,"s3://crabby-images/b7653/b76538ba9fc37df48746ca9eaa7602f397838b0e" alt=""
I also had a Table of one day events, where I wanted to include the correct rental amount.
data:image/s3,"s3://crabby-images/17cc2/17cc2393e58e21f263127f4d11dc4f8242ac6c51" alt=""
Last time, I expanded the tent rental data so that I had an entry for each date. This time, I am going to create a function to extract the correct rental amount. I will extract my rental data to Power Query, by using ‘From Table/Range’ in the ‘Get & Transform Data’ section of the Data tab. I will call it Rental Step, as it is the table that I will be creating a function from.
data:image/s3,"s3://crabby-images/63af2/63af2194e787f84babd2833057d85a013605c6b0" alt=""
There are different ways to create a function. I am going to follow a method which involves creating as little manual M code as possible! I am going to create a parameter to filter Date and a parameter to filter Tent Type before I continue. I can do this from ‘Manage Parameters’ on the Home tab:
data:image/s3,"s3://crabby-images/347f8/347f8a4fdce82270726c881483a777a03a34665d" alt=""
My date parameter is called P_Rental_Date:
data:image/s3,"s3://crabby-images/1b404/1b404bdae3b833ed29eb1844c0759315aa8f33e0" alt=""
I have deliberately chosen to default to a date which I know is later than my rental data. This will make it obvious that one of my later steps is required.
The next parameter is P_Tent_Type:
data:image/s3,"s3://crabby-images/5995e/5995ed10c21c0e6b4bbaea5ffee6ca27382379c7" alt=""
I choose a Tent Type value as the default.
Having created my parameters, I go back to Rental Step and apply a filter to Date.
data:image/s3,"s3://crabby-images/d6884/d68842541edd61173cf160b56c65d974af9db2f3" alt=""
Note that this screen can be accessed by choosing any filter, and then ‘is before or equal to’ can be selected from the dropdown. I choose to filter dates before or equal to P_Rental_Date, which will currently select them all because of the late date I chose for the default.
I then apply a filter to Tent Type.
data:image/s3,"s3://crabby-images/f433e/f433eeb23f18d0b09487fd9938ade7781ab0cf0f" alt=""
As this is currently set to “Large”, I will get all rows for “Large” with any date.
data:image/s3,"s3://crabby-images/7588f/7588f6d118ed0e1864320b4ffa23b977fb1adcc8" alt=""
This is why I chose to default P_Rental_Date to a date later than my data. I can see that, to get the latest rental information for “Large” at the top, I need to sort the dates in descending order.
data:image/s3,"s3://crabby-images/6ea80/6ea80c0832035ddf1273a5ca93b2845267171aa3" alt=""
Now I need to calculate the Rental Rate, so I only want that column.
data:image/s3,"s3://crabby-images/cee72/cee7223b11820716e22eff6402ec13a4d7abeac0" alt=""
Finally, I drill down into the latest Rental Rate so that I only have the latest value. I can do this by right-clicking on the cell and selecting ‘Drill Down’.
data:image/s3,"s3://crabby-images/a8c16/a8c1698bf979700aa386176c86581e96e56035a3" alt=""
Finally, I can convert my query to a function. As I am going for the route of least M code, I do this by right-clicking on my finished query.
data:image/s3,"s3://crabby-images/1c701/1c701df0dd41c52048988e7cb4c9d99a67eed6d2" alt=""
I am then prompted for the name of my function:
data:image/s3,"s3://crabby-images/1a1ce/1a1ce337796700d4ac7547fad1705a3775b6ba65" alt=""
I create fx_Rental:
data:image/s3,"s3://crabby-images/8e139/8e1395a2e2f3e18c23b3cfb2c39ecf191df81670" alt=""
All the M code has been created for me, and even better, I can change my function by amending the steps in Rental Step rather than using the Advance Editor here. In fact, if I try to call the Advanced Editor, I am warned not to break the link:
data:image/s3,"s3://crabby-images/09837/09837926d1e097d66c0d4f044a5ae0968af7af11" alt=""
Now I can go back to the events data and add a new column from the ‘Add Column’ tab.
data:image/s3,"s3://crabby-images/e6656/e66562db94c353b8dbac5be513d8f0f350ef67d7" alt=""
By choosing ‘Invoke Custom Function’ I can call my new function and pass Event Date and Tent Type as the parameters.
data:image/s3,"s3://crabby-images/084ea/084ea53089aba63089bc8f1ca14d4ea4c432713b" alt=""
I have the same results as last time.
Come back next time for more ways to use Power Query!