Power Query: Rental Wrangles Receipts - Part 1
11 August 2021
Welcome to our Power Query blog. This week, I look at an example where I need to transform my data before I can apply a function.
Last time, I was looking at how to extract the correct rental information for an event, where only one tent was being rented. This time, I am looking at larger events where I have list of tents required for each event.
data:image/s3,"s3://crabby-images/0b275/0b275b5aada8eafe3c2e134dca4fb539bfe8ea2e" alt=""
With such large groups involved, I’ve had to return to 2019 for this example! I start by extracting my data to Power Query using the ‘From Table/Range’ option on the ‘Get & Transform Data’ section of the ‘Data’ tab. Since the process for the rental data is the same as last week, I can skip to the function created.
data:image/s3,"s3://crabby-images/9cd47/9cd4730b05495f955aa4367aaf480a41391faad9" alt=""
The function is ready to be applied to the event data. I ‘Close & Load To’ and create my function and the supporting table as ‘Connection Only’ queries. I go back to the Excel Worksheet and extract my data.
data:image/s3,"s3://crabby-images/9c935/9c935754d7e021ed42444daaaa77e29f8ddfc953" alt=""
I take the defaults and create my query, which I call Event Data:
data:image/s3,"s3://crabby-images/60a81/60a81a0837f2ce25fc34060eec008ba94cf5a2f7" alt=""
I need to divide the Tents Rented column in two different ways. First, I need to create a row for each tent type, and second, I need to separate the quantity and tent type into different columns. I will be using the ‘Split Column’ functionality for both tasks. I can access ‘Split Column’ either by right-clicking my column or from the Transform and Home tabs.
data:image/s3,"s3://crabby-images/b735f/b735f41a11c6565c65b8f489a039b3ab754ef8af" alt=""
I choose to split ‘By Delimiter’:
data:image/s3,"s3://crabby-images/58e7b/58e7b6c555c136fc2c3bbb7f6dc8439acdb216b4" alt=""
I choose to ‘Split into Rows’ in the ‘Advanced options’ section and opt for a Custom delimiter.
data:image/s3,"s3://crabby-images/8fc2e/8fc2e3bdfba71b8b0978b3c7f912baba1427f307" alt=""
The delimiter I am using is comma followed by a space (, ). This means there will be no space before the numbers.
data:image/s3,"s3://crabby-images/325ef/325efb785c9894e2bb5c9357112f11b4a3f0af09" alt=""
I now have rows for each tent type with the quantities. It’s always a good idea to check that all steps generated are needed. In this case, the Split Column step has automatically been followed with a Changed Type step. This would be useful if I had created new columns, but since I have created rows instead, this step is not needed, and I can delete it.
I split the column again:
data:image/s3,"s3://crabby-images/f6a53/f6a532e5f65fc94c211d31fd59920f1d2c087826" alt=""
This time I am going to split ‘By Digit to Non-Digit’, to extract the tent quantities.
data:image/s3,"s3://crabby-images/605ec/605eccc306708f0758490ae002d59898267a56a2" alt=""
Ironically, I don’t have an automatically generated Changed Type step this time! I rename Tents rented.1 to Quantity and Tents Rented.2 to Tent Type. I also change the data type of Quantity to be a whole number, which I can do from the Transform tab. Since I am going to use Tent Type as a parameter, I also remove any spaces. I can do this by using Trim from the ‘Format Options’ dropdown on the Transform tab.
data:image/s3,"s3://crabby-images/e4972/e49727c570150808190864ebcb6bf31d87fc4fef" alt=""
This will remove any leading or trailing spaces.
data:image/s3,"s3://crabby-images/7daf7/7daf7b709ef0f0a7bd1c4f37123577902226f5e1" alt=""
The next step is to create a Custom Function Column by ‘Invoking Custom Function’ from the ‘Add Column’ tab.
data:image/s3,"s3://crabby-images/e728e/e728eb7cd6e1f976b118e621db575a70de8523ea" alt=""
I call the new column Rental Rate and invoke fx_Rental, passing Tent Type and Date as the parameter values.
data:image/s3,"s3://crabby-images/cf1c6/cf1c6d942711266a41ae22b8864e818336896014" alt=""
Before I continue, I change the data type of Rental Rate to be a currency.
Now I just need to perform a simple multiplication. I choose to do this from the ‘Add Column’ tab to keep the data for each tent. I select Quantity and Rental Rate (with the CTRL key held down).
data:image/s3,"s3://crabby-images/31bb2/31bb2f2d7e5d4016aa1584dd18061454a74e6d7e" alt=""
Choosing Multiply from the dropdown list of Standard mathematical functions will create a new column, which is a product of Quantity and Rental Rate.
data:image/s3,"s3://crabby-images/a9fdb/a9fdb88454c48c9edd3f6a3274e883334be2df21" alt=""
I rename Multiplication to Rental Amount.
data:image/s3,"s3://crabby-images/e882c/e882cab9e29fc10308bef3288a188d7849e94f75" alt=""
That is where I will leave it this week. Next time, I will recombine my data so that I have one line for each event.
Come back next time for more ways to use Power Query!