Power Query: PDF Pandemonium – Part 6
20 October 2021
Welcome to our Power Query blog. This week, I continue transforming some data that is coming in from a PDF file by working with last week’s function.
The tent business is doing well, and the UK division have plans to expand the workforce. I have a PDF file, and it contains tables for 10 stores. Last week, I created a function to apply to the Stores table.
data:image/s3,"s3://crabby-images/1940c/1940c5c1ab14be121a5eac48e40a2c26a8b863c6" alt=""
In the Stores query, I need to make sure I only have the columns I need. To do this, I will remove the ‘Demote Headers’ step. I can reapply it before I invoke the function.
data:image/s3,"s3://crabby-images/afd98/afd98f35f48f555749addbff1bc05eeadd1db547" alt=""
This means I have the store names in the headings to choose:
data:image/s3,"s3://crabby-images/e44f6/e44f6cf341f4df0730661fdca1f75c3bad497d70" alt=""
This gives me the store columns, and I can demote the headers again:
data:image/s3,"s3://crabby-images/679fe/679fe5161bccaa33b18ce016aca0ffcf1b374102" alt=""
Stores is ready to use as the Source for fn_store. I go back to fn_store:
data:image/s3,"s3://crabby-images/4e9eb/4e9eb65076fbb54132651c499162400401db0fa1" alt=""
I need to provide a column from the Stores query.
data:image/s3,"s3://crabby-images/54224/54224971beeaa0fa6d447fe33ee356536b57c278" alt=""
I use Column1:
data:image/s3,"s3://crabby-images/69238/692389c1eaffee204cf6c2629b9152ef353a74f0" alt=""
Invoking this query will give me a table:
data:image/s3,"s3://crabby-images/e7638/e76385035134f88de05aac8d929d65cc34132b22" alt=""
I rename this table Expansion by Store. I am going to use the M code already generated as a basis for this query.
data:image/s3,"s3://crabby-images/85744/8574481ea41511a361487690badb8934a3e3371e" alt=""
I take the M code created for Column1, and replicate it for 10 columns. I have renamed the steps to make it clear what I am planning. I will rename the final ‘in’ statement when I have finished:
data:image/s3,"s3://crabby-images/d7728/d772834d3fcbbf7e9d77142c97ee1c9e4560a646" alt=""
I have created a table for each store; now I just need to append them. The M code function to append is Table.Combine({table1, table2,….}). I add this line to the M code in the Advanced Editor.
data:image/s3,"s3://crabby-images/8d143/8d14396bcdbe2f50969ae91bc4ce82c5d48d173a" alt=""
I click ‘Done’ to see the results:
data:image/s3,"s3://crabby-images/4e7f1/4e7f1b0abe69a4b91963d56b2ffac105c5f95ad2" alt=""
I have the results in the format I wanted for all stores. I can now ‘Close & Load’. I will choose ‘Close & Load to…’ so that I can load to ‘Connection Only’ to begin with to avoid loading all queries.
data:image/s3,"s3://crabby-images/e3458/e34586d8e1cb3a8f881b1c914c3b01c9076dcc77" alt=""
I can then right-click on the queries I want to load, and position them together:
data:image/s3,"s3://crabby-images/f885d/f885d391023ded11ae59024f459f67e2fa763a47" alt=""
I load the tables onto a worksheet:
data:image/s3,"s3://crabby-images/18a6d/18a6dd3b3d0698c3410b3f2c7500a77bffeaa7a6" alt=""
I check the data types and the report is ready.
data:image/s3,"s3://crabby-images/ec3df/ec3df3e2907e227b0bef90b4943d46b320facd34" alt=""
Come back next time for more ways to use Power Query!