Excel Parameters in Power Query
Overview
For certain modelling situations, you may want to pass a collection of parameters from Excel to Power Query. In this article, we explain how to do this, passing the given parameter in, as a variable:
Extracting orders of particular date
Suppose you have the following Order data. You would like a single cell in Excel, which holds a date, to be passed into Power Query, so that when the query is refreshed, it updates to show only those orders of the passed in date.
data:image/s3,"s3://crabby-images/ad53c/ad53c7908017e61365384963fea30226e734a7e0" alt=""
The following steps explain how to do this:
Steps
1. Set up a Parameter as a table
- Create a single cell table that contains the date of the orders to extract.
data:image/s3,"s3://crabby-images/78276/782762d89fc8db90146386c7efdad8885bdc9997" alt=""
- Click in the table ➔ click the From Table / Range icon under the Data tab, in Excel
data:image/s3,"s3://crabby-images/9a437/9a43729e7c5649f8318c5da372343fdd9fdf0c7b" alt=""
The table should load into Power Query as a single celled table. The date cannot be used in this tabular format, so needs to be drilled down on. To do this:
- Right click the cell, and choose Drill down
data:image/s3,"s3://crabby-images/443c8/443c889810987d1c6f592c7ebc419d92fa87a6d5" alt=""
Now only the actual value should be returned, as a scalar value, like so:
data:image/s3,"s3://crabby-images/51644/51644391f946b07ef98720f470590e123a9a4ad7" alt=""
Now that this is a value (the scalar value, can be directly used inside another query.
2. Extract the required data for any random date
Next, create a query to extract the required data from the database.
- Load the underlying data into the Query Editor
- Apply a filter from the drop-down box, for any random date, as shown:
data:image/s3,"s3://crabby-images/edc54/edc54d4bc4f3560ab443454e41d204a9028511b4" alt=""
This will create a query step that references the date selected above, with the following code.
data:image/s3,"s3://crabby-images/bc151/bc151cb59831398211d7fdfdfd9189e678281a4e" alt=""
3. Link to the Parameter table
- Now, replace the hardcoded date in the code above, with the name of the Parameter query created before
data:image/s3,"s3://crabby-images/e1555/e155529bdaa2cf05b384f1b9e5381b03849a1f8c" alt=""
- Select Close & Load, so the query loads to the original spreadsheet.
data:image/s3,"s3://crabby-images/f36b6/f36b6a214a440134d22b2140d3b47704e10674b8" alt=""
- To check that everything works, change the date in the Parameter table, and refresh the query table again.
The query should return orders with a date that match the parameter table!
data:image/s3,"s3://crabby-images/bb139/bb1395f35cf6c6108251402c618b0bd6aa0c606f" alt=""
Feedback
Submit and view feedback