Power Query: It’s Good to Share(Point) Part 8
13 November 2024
Welcome to our Power Query blog. This week, I transform the data from a SharePoint list.
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 started with a single file and then moved on to consider combining data in a SharePoint folder.
Last time, instead of a folder, I looked at a SharePoint list:
data:image/s3,"s3://crabby-images/6e080/6e080d809f990229564b872d851b97e84b6b76f3" alt=""
Along with the flattering pictures, the salespeople are responsible for creating expense files and these are linked as attachments. I would like to extract a table with the attached expenses and the responsible salesperson. Regular readers will not be surprised to discover that the expense files are CSV files, I’m sure!
Last time, I accessed the SharePoint site, and selected my list:
data:image/s3,"s3://crabby-images/98b99/98b9921273b9f17934a4eed0594a4552e0027890" alt=""
I chose to ‘Transform Data’ and selected the columns I wanted to keep:
data:image/s3,"s3://crabby-images/ce27f/ce27f0fbed696b8f3719e9198755e267b01bfb86" alt=""
Next, I need to extract the expense data from the tables. Before I extract any data, I click in the space next to a table to see what is in the columns:
data:image/s3,"s3://crabby-images/f1914/f19146fdb73d64fc0b0b439e2746a1382c4c71d3" alt=""
Now I can see which data I need; I begin by using the expand icon next to the title of AttachmentFiles:
data:image/s3,"s3://crabby-images/252a1/252a1678c240f69382527402476ad7e40cea8bee" alt=""
I know from the previous ‘peep’ that I need the data in FileName:
data:image/s3,"s3://crabby-images/a19ee/a19ee67785362632c572db01c93ab781a7283eff" alt=""
I see that I have different data types here. I only want the CSV files. I begin by extracting the data after the full stop, or period, to a new column. On the ‘Add Column’ tab, I choose to Extract ‘Text After Delimiter’:
data:image/s3,"s3://crabby-images/7e753/7e75352103b2e3a87887609cdc53e7262c759927" alt=""
I choose the full stop or period as the delimiter:
data:image/s3,"s3://crabby-images/07665/07665b5a858cd010ca66d1a8aa9456ed98363e96" alt=""
This gives me a new column with the extension,. To ensure I pick up any files with extension csv or CSV, I transform this column to UPPERCASE:
data:image/s3,"s3://crabby-images/adf92/adf92c01e1f2879316e62d776537b6a899699283" alt=""
I may now filter to select the CSV files:
data:image/s3,"s3://crabby-images/72fd5/72fd53fb0f31b1b125a676b9e4e205aea25d8c0d" alt=""
I could add further filters to ensure that I only had the expense data if I had other CSV files attached, but this is sufficient for now. I remove the Text After Delimiter column that I have created:
data:image/s3,"s3://crabby-images/6d094/6d09431deaa67e4641aa1e85838710408d8a28c1" alt=""
I have the data I wanted, and I may use this to merge with other expense queries.
Come back next time for more ways to use Power Query!