Power Query: Passing (Reference to) Excel Parameters
28 February 2018
Welcome to our Power Query blog. This week, I take a look at how to pass Excel data as a parameter in Power Query.
I am going to look at a simple scenario where I use a parameter in Power Query which is populated from a cell in my Excel workbook.
Below, I have a spreadsheet with charge data pertaining to items in my fictitious inventory:
data:image/s3,"s3://crabby-images/84b67/84b6770322123076722a2c8c0d5337ed499061bf" alt=""
My plan is to create a query from ‘Charges’ data, and pass a parameter from the ‘Items’ sheet.
data:image/s3,"s3://crabby-images/5d264/5d2643d142f6aa72f19b29475b078dcae9bbabc1" alt=""
I am not claiming that this is the most efficient approach for this particular scenario, but it will serve to show the method!
I create the parameter first, so that it is ready to add to my main ‘Charges’ query. Since my cell is already in a table of items data, trying to create a new query from the ‘Data’ tab by choosing ‘From Table’ in the ‘Get and Transform’ section will assume I want the whole table. I can circumvent this issue by using the method I used in Power Query: Returning to Referencing Ranges. If I give my prospective parameter a range name, then I can locate it easily in my workbook. I name my cell ‘Parameter_Range’ and create a new blank workbook from the ‘Other sources’ option of the ‘New Query’ dropdown, viz.
data:image/s3,"s3://crabby-images/ca013/ca013aa29acd5705488b5b86e480639756590dc0" alt=""
In my new blank query, I enter the following M function:
Excel.CurrentWorkbook(){[Name="Parameter_Range"]}[Content]{0}[Column1]
which will extract the value from the cell. I rename my new query ‘Item_Parameter’ and save it as a ‘Connection Only’ query.
data:image/s3,"s3://crabby-images/85ab3/85ab31b8500b9c12bd97fd6c1a0fbb42a63a09bc" alt=""
Now I need to create a query on ‘Charges’ which will select charges that match a particular item. I will do this using the GUI options available. I create a new query ‘From Table’ whilst in my ‘Charges’ sheet:
data:image/s3,"s3://crabby-images/fcfee/fcfeefd1d226926d689e06cad6ab0c4695ef2dea" alt=""
I can then choose to filter on Description:
data:image/s3,"s3://crabby-images/433e2/433e25c8d10215882bf5a1ec02660de9bc0b5966" alt=""
It doesn’t matter which description I pick at this stage – I am simply getting Power Query to create the step for me.
data:image/s3,"s3://crabby-images/b4890/b4890b47175fe37ffa448eaa9645c1bf278084b6" alt=""
Now I have the step, instead of picking those charges that are pertaining to ’10 x 4 metre marquee’ I want to use my parameter instead. If I expand the ‘Queries’ pane to the left of the screen, I can make sure I have the correct name.
data:image/s3,"s3://crabby-images/ca11f/ca11f8669cda8e0aea77932aa727fccda20eb21b" alt=""
I then select the tick icon (left of the formula bar) to change the step to use my parameter.
data:image/s3,"s3://crabby-images/41de1/41de1123436294af6f6c1802667431d24a1aa19f" alt=""
The correct data is shown. I can update the parameter (by changing the cell or editing the named range) in my Excel worksheet and refresh the query to change the data that is selected. I try this by changing ‘Item_Parameter’ to point at the next item description.
data:image/s3,"s3://crabby-images/63c23/63c23c797df4f179a4df8c9a05b9e13ab2fe35fa" alt=""
Before I refresh my query, the original data appears:
data:image/s3,"s3://crabby-images/8cc74/8cc74c24194f523de28e9a4da628974c382e5e79" alt=""
Once I refresh my query, the new parameter value is used.
data:image/s3,"s3://crabby-images/0041c/0041c7a87e209c5199a9a18e9981ff0cdca1091e" alt=""
Want to read more about Power Query? A complete list of all our Power Query blogs can be found here. Come back next time for more ways to use Power Query!