Power Query: Interactive Query
10 April 2019
Welcome to our Power Query blog. This week, I look at how to make a functional query more interactive.
Last week, I created a query that could receive date parameters.
data:image/s3,"s3://crabby-images/b8764/b876439aa730247f488abe0df0f3b108c8af9693" alt=""
data:image/s3,"s3://crabby-images/4df2d/4df2dbf7c4e38304c9784ffb1400385e1b0c90bd" alt=""
This week, I amend my query so that it’s more flexible for users by allowing the parameters to come from the worksheet. The first step is to put the dates into the worksheet:
data:image/s3,"s3://crabby-images/00e1a/00e1a5999d3e6878fb78d13887c3fd5a0e689eb5" alt=""
I don’t need to worry about making this a Table, as when I extract this information using ‘From Table’ in the ‘Get & Transform’ section on the ‘Data’ tab, Power Query will automatically convert it to a Table. Having said that, it’s a good practice to convert to a Table first, as you get to choose the name of the Table before importing.
Having said that, let’s pretend I ignored my advice:
data:image/s3,"s3://crabby-images/b9b07/b9b07c47818520465d213c4575790ca10eaf471f" alt=""
I confirm the defaults to extract the information to Power Query.
data:image/s3,"s3://crabby-images/d36c3/d36c327fa17fe313f30733fab0d2afc2ab0d22ad" alt=""
Now I need to connect these parameters to the query I created last week, ‘Expenses_Folder’. To do this, I create a new custom column from the ‘Add Column’ tab:
data:image/s3,"s3://crabby-images/431e3/431e3f388211880a14e182aa6d398f31ca646cfa" alt=""
Since ‘Expenses_Folder’ is a function, I can use the M code
= Expenses_Folder([datefrom], [dateto])
which calls my original query as a function, using the dates in the columns in my current query.
data:image/s3,"s3://crabby-images/78a97/78a97dd30ef7335efa25126e719350a69c139d6c" alt=""
The content of my new column is a Table. I can use the ‘Expand’ icon next to the title of the column to view the contents of that Table.
data:image/s3,"s3://crabby-images/21ce6/21ce63377a2a07ea68b07ca837fafb69e803a6b1" alt=""
As usual, I don’t want to use the original column name as a prefix (that would make for very long column names!). I select all columns in the Table and choose to expand.
data:image/s3,"s3://crabby-images/8339d/8339de65be925feae4c9ef303591dc55337aa084" alt=""
All the data from my original expenses information is shown where the date falls into the range I have specified. I remove the datefrom and dateto columns and save the query by using ‘Close & Load’ from the ‘File’ tab.
data:image/s3,"s3://crabby-images/0224e/0224eab6474910be7c0708e6eacfe7bc135f4421" alt=""
I have renamed my new query ‘Interactive Expenses_Folder’.
If I go back to the original data worksheet, I can change the dates and see what happens to my query.
data:image/s3,"s3://crabby-images/9bc7e/9bc7ea262e669dc800205b6d9d168c7f834b441b" alt=""
Once ‘Interactive Expense_Folder’ is refreshed, I can see that the expenses from May are displayed.
data:image/s3,"s3://crabby-images/afdbb/afdbbec2386a1e62f5c93c3afc5e358ef2575b94" alt=""
This is a quick and easy way to reduce the amount of data that I have to deal with.
Come back next time for more ways to use Power Query!