Power Query: A Tangled Web Part 1
26 February 2025
Welcome to our Power Query blog. This week, I use the ‘Add Table Using Examples’ functionality to create custom tables from web data.
When extracting data from the web version of Power Query, it utilises M code to access the data in a form that can be used in reports. Over the next few blogs, I am planning to examine the M code produced. The data I will use to investigate web data is from our very own website:
data:image/s3,"s3://crabby-images/723d7/723d716be47f7843d5a4d6fe1e7caf387a6da633" alt=""
This page contains a table of upcoming courses, along with various buttons and text:
data:image/s3,"s3://crabby-images/fcd45/fcd455064d4a4079ff70f64ca6a75043c2bb8f3e" alt=""
In a new Excel workbook, I access ‘From Web’ in the ‘Get & Transform Data’ section of the Data tab:
data:image/s3,"s3://crabby-images/082da/082dae3d672590c5302f9204e9544b9c1e50eaf9" alt=""
I enter the URL https://www.sumproduct.com/courses:
data:image/s3,"s3://crabby-images/d8b75/d8b7520cbb9d1626f7b5edab382c601fae2dfd78" alt=""
As I have accessed our website many times, the connection details exist for me already; I have used the default Anonymous credentials. When I click OK, I may view the Navigator dialog.
data:image/s3,"s3://crabby-images/22fc2/22fc2e53ef5c55aa499b9e401ebb66b4aa0fa338" alt=""
I want to examine the way that the web connector automatically creates M code for the different options on the Navigator. In addition to the data already available, I am going to create another table using the ‘Add Table Using Examples’ functionality.
data:image/s3,"s3://crabby-images/6e054/6e05438a7c3135bb1b4f12aa34ec940ef5962b37" alt=""
I have named the first column Course Name and started typing the first course name from the table on the webpage. I have been prompted with some options from the page. Note that not all the options are from the table. For example, ‘Contact Us Today…’ is from lower in the page.
data:image/s3,"s3://crabby-images/27abd/27abd347dc67070bcd43c53d95c4a66f9ce1a725" alt=""
I double-click on the course name in the dropdown and repeat the process for the second row. The algorithm fills in the rest of the data for this column and I choose to add another column using the ‘+’ icon.
data:image/s3,"s3://crabby-images/a7a8e/a7a8e09f0b51b160aefaeb8cc9d62c4de6a6afd2" alt=""
Having added two [2] more columns from the table, I choose to add some data from elsewhere on the page.
data:image/s3,"s3://crabby-images/adfbb/adfbba16d18291567b7ea7d39c1b57a763225db9" alt=""
Since this does not occur in the table, it is not filled down for me. I also get a message when I press ENTER to accept the value:
data:image/s3,"s3://crabby-images/bf106/bf106122c4155e08d3119219131886d2c9d3713a" alt=""
Trying to add data outside the table I was looking at has given me an error:
‘No CCS selector was found for the sample values you provided in the following column(s): Contact’
It appears that I cannot combine data from inside a table and data outside of that table in the same custom table. I will add the current custom table, and then add the training contact separately by using ‘Add Table Using Examples’ again:
data:image/s3,"s3://crabby-images/fdb61/fdb61b815f93e30552d3649d04956a27829c49ae" alt=""
I enter this data and click OK:
data:image/s3,"s3://crabby-images/442ee/442ee2ed293df232b794b1dec0a91392a2dad750" alt=""
The training contact data has been captured in Table 2 but not in Table 1:
data:image/s3,"s3://crabby-images/25519/25519602ded6999c83dfbf875784347a20eca62c" alt=""
Next time, I will use ‘Transform Data’ to view the M code used to capture the data I have chosen.
Come back next time for more ways to use Power Query!