Power Query: Keeping it Current – Part 2
13 July 2022
Welcome to our Power Query blog. This week, I start to convert the query to look for data in the current workbook.
In Power Query: Sheets Ahead – Part 1, I uploaded data from multiple sheets into another workbook. I had some simple monthly data:
data:image/s3,"s3://crabby-images/d6c82/d6c82ed66bd509d8acb257987ae3d1666ff0defa" alt=""
This sheet is for January; I had a similar sheet in the same workbook for February:
data:image/s3,"s3://crabby-images/d48ae/d48ae711be8f33fa5f23f63e83df8da750adcfce" alt=""
I created a query that not only concatenated this data, but also included the sheets for other months as they appeared if I refreshed it. This query was in a separate workbook:
data:image/s3,"s3://crabby-images/ef65a/ef65a612e5de468f016f3f6d6891b64bc01e5c40" alt=""
Last week, I copied this query to the original workbook containing the source data:
data:image/s3,"s3://crabby-images/331be/331be6f82d6bab15fd36920846a999f81edb0eee" alt=""
The message is telling me the query can’t access the workbook because I have it open. This is true since it is this workbook. However, I have the M code, and this week, I will change it to point to the current workbook.
I close the error dialog and right-click on the Monthly Sales query, so that I may Edit:
data:image/s3,"s3://crabby-images/584af/584af1b63967f1e009c8a2a0bc5848af79423978" alt=""
This takes me to the Power Query editor, where I select the first step (Source).
data:image/s3,"s3://crabby-images/e12a0/e12a008e50c3d356b50a1142b815928f41b73b2f" alt=""
The M code for this step is:
= Excel.Workbook(File.Contents("C:\Users\kathr\OneDrive\Documents\SUMPRODUCT\PQ Blog\PQ blog 279 and 280 Sheets Ahead.xlsm"), null, true)
Instead of pointing at an external workbook, I need to change this to use the current workbook.
I can use Intellisense to help me here. If I delete ‘Excel.Workbook’ and start typing, I can see the following available functions:
data:image/s3,"s3://crabby-images/7e39e/7e39e3e322401d0fd82f1704be7599de3b2a17ad" alt=""
Therefore, instead of Excel.Workbook(), I can use Excel.CurrentWorkbook().
data:image/s3,"s3://crabby-images/27582/2758246d308e3807f45e65f01d0d6d653cd5c45a" alt=""
Since I have a location, I don’t need the parameters, so I may delete them. Note that the Expression.Error dialog tells me that no arguments are required.
data:image/s3,"s3://crabby-images/ca2f9/ca2f9ba4879f66ff32e9831d0408d4053a555cea" alt=""
Here, I have the current issue with accessing data from within the workbook: I can see the tables (and Named Ranges) but not data on the sheets.
Next time, I will adapt the query and the data to get the results I need.
Come back next time for more ways to use Power Query!