Power Query: It’s Good to Share(Point) Part 3
9 October 2024
9 October 2024
Welcome to our Power Query blog. This week, I successfully extract a CSV file from a SharePoint site to Power Query.
In this series, I am considering how to access data on SharePoint. SharePoint is used by many companies to store organised data which may then be accessed and shared throughout the organisation. I will be starting with a single file and then move on to consider combining data in a SharePoint folder.
The data for this series will come from the following SharePoint folder:
data:image/s3,"s3://crabby-images/450e3/450e3a1619337dee555515c7d2f58e097306918c" alt=""
Regular readers will be familiar with the expense data in the form of CSV files, I’m sure!
In Part 1, I established that it wasn’t sufficient to use the mapped drive on my PC that points to the SharePoint Site:
data:image/s3,"s3://crabby-images/a3298/a3298382feec6f41de8357cb1539984909addd55" alt=""
I would like to create a solution that can be shared with needing to change the path in File.Contents(). I need to use the ‘From Web’ option in the ‘From Other Sources’ section on the ‘Get Data’ dropdown:
data:image/s3,"s3://crabby-images/9801b/9801b384426c4ae494c7ba2d65ba4efd6fa1ed63" alt=""
This prompts me for the URL for a webpage, which in my case will be the CSV I wish to access:
data:image/s3,"s3://crabby-images/13e06/13e0628dbfdb6de7c7cce7ac0c95e77f13099dfb" alt=""
Last time, I copied the URL from the SharePoint file:
data:image/s3,"s3://crabby-images/7cfa3/7cfa346e03f049f3ef15da70d278ce2895fa04a7" alt=""
I used this information in the ‘From Web’ dialog in my blank Excel workbook, using the shortcut CTRL + V:
data:image/s3,"s3://crabby-images/b23e1/b23e1580669470448e6b3a0d0fd3599c8fbd9be1" alt=""
After choosing the access method, I am prompted to ‘Sign in’ to SharePoint.
data:image/s3,"s3://crabby-images/1df47/1df47fbc08d57fdb918bc29702add569902b6bf2" alt=""
Having signed in, I click Connect.
data:image/s3,"s3://crabby-images/3840b/3840bc12cd0068433de82cea078635f90bd3dce4" alt=""
I receive an error telling me to modify the URL, which is currently in the form:
I choose to Edit, and remove the string ‘?web-1’ as requested:
data:image/s3,"s3://crabby-images/5092c/5092c055f98781dd66ff5552d44bc4c5ce859807" alt=""
I may now click ‘OK’ to import the CSV:
data:image/s3,"s3://crabby-images/26b53/26b535086ecf53f03a3ca998d6a567bb7de9215c" alt=""
Note that I am not presented with the web Navigator dialog: this is the same dialog that I would see when importing a CSV file from my computer. I choose to transform the data:
data:image/s3,"s3://crabby-images/54e86/54e86652c96c0ea1a841f56671635e4e65fdaf69" alt=""
This time, the Source step is extracting the data from the web, which means that another user in my organisation may access these queries. However, since I am using my credentials, and they are saved to allow me to access the same data without entering the credentials again, I may wish to remove my saved credentials.
I may access the credentials from the File tab, where I find ‘Data Source Settings’ on the ‘Options and Settings’ tab.
data:image/s3,"s3://crabby-images/8f2d6/8f2d6492fffdade67325e9cd502411b4a818ff42" alt=""
This allows me to view any saved settings for data sources I have used.
data:image/s3,"s3://crabby-images/fa4fb/fa4fb8e34b7554e41adc130523e420034ee5b3b8" alt=""
I am only interested in the ‘Data sources in current workbook’. On the ‘Clear Permissions’ dropdown I have two options:
data:image/s3,"s3://crabby-images/c0913/c09134bde4ac06df7dbcb1b3fff5a17c6a54d406" alt=""
If I had other sources in the workbook that required credentials, I could choose to ‘Clear All Permissions’ to clear permissions from all sources. I choose to ‘Clear Permissions’.
data:image/s3,"s3://crabby-images/7ba02/7ba02b95e29aa804005b394bab4e29e02e6a13de" alt=""
I receive a warning, to make sure I am aware that this is irreversible. I choose to Delete and close the dialog. When I refresh, I see the same prompt that a user sharing this workbook would see:
data:image/s3,"s3://crabby-images/93809/938095157c72f1d51d7ad71bc7bd34f1e4a108be" alt=""
When I choose to ‘Edit Credentials’ I see the same dialog that appeared when I imported the CSV:
data:image/s3,"s3://crabby-images/801c4/801c4b55781f3dd51615ec531bf582c928eb80be" alt=""
If I had chosen to find the URL using a copied link, I would have had confusing results:
data:image/s3,"s3://crabby-images/b24b2/b24b220c4636726510067272d72062ed79cdbea6" alt=""
This creates a link to the CSV that may be shared:
data:image/s3,"s3://crabby-images/d4334/d4334ce218b67fbc8b948d92403888a0a3823002" alt=""
However, if I enter this into the dialog in my new workbook, I have an issue:
data:image/s3,"s3://crabby-images/2c626/2c626460a65dc1cd8022e7dad838344d5e73b7ee" alt=""
This is not actually a problem with the credentials; it’s a problem with the URL.
Now I have successfully linked to a single CSV file, next time I will use the ‘From SharePoint Folder’ option to combine all the CSVs in the folder.
Come back next time for more ways to use Power Query!