Power Query: Find the Folder
6 March 2019
Welcome to our Power Query blog. This week, I look at an example which uses some of the M functionality for dealing with files and folders.
Last week, I created blank queries and used M code to extract data from a folder in Power Query. In Power Query: One Folder, One Query, I created a query that contained similar data from a folder, which I could then combine. This time, I am going to use a similar method and take a different path through the options so that I can view the subfolders in a folder.
data:image/s3,"s3://crabby-images/7df1a/7df1a211c012eb64de6c84ebb24a8f4bd945e119" alt=""
I begin by creating a new query ‘From Folder’ by choosing this option from the ‘From File’ dropdown in the ‘New Query’ section of the ‘Get & Transform’ functionality on the ‘Data’ tab.
data:image/s3,"s3://crabby-images/f87ff/f87ff0e1f2149e306c55624d598900c95dbfca4e" alt=""
Power Query prompts me for the location of the folder and I choose to browse:
data:image/s3,"s3://crabby-images/4faf4/4faf46ed20b3e58da6480899ba5a86dcd589393f" alt=""
data:image/s3,"s3://crabby-images/4ecfd/4ecfd25ca00c647c1314d4c406b979f764db989d" alt=""
I find the folder which contains my ‘PQ Blogs’ folder.
data:image/s3,"s3://crabby-images/73302/73302741a3ab51a6a282cad76c4879cb0ed9e25d" alt=""
In the preview, I can see a list of documents and workbooks, but no folders. Unlike the aim in Power Query: One Folder, One Query, this time I want to see all file types in the folder. I don’t want to combine the data; I want to edit it so that I can look for specific data in the folder.
data:image/s3,"s3://crabby-images/4ac84/4ac84e823ac31762a29f87f4ab7cf054e5a73fac" alt=""
Now I have chosen to edit the data, I can see the M code behind the query.
= Folder.Files("C:\Users\kathr\OneDrive\Documents\PQ_StandardExpenses")
This is the same code used in last week’s blog. In this case, I want to use Folder.Contents() instead of Folder.Files(), because I want to see the subfolders, and not just the files in the subfolders.
data:image/s3,"s3://crabby-images/8ea6a/8ea6a507687419833c69825ce7d520d49a2adc4b" alt=""
The first row shows me the ‘PQ Blog’ folder. The Content column indicates that this is a table, and I can see the contents of that table (the files) by clicking on ‘Table’:
data:image/s3,"s3://crabby-images/7f758/7f758e339178dbc3773c1c3a4f84ae732dcc32f2" alt=""
I want to just show Content which contains a table, which will allow me to only view folders.
data:image/s3,"s3://crabby-images/3d5a8/3d5a8ffe485e53886cdf564f2648c69bf14fa3e3" alt=""
However, I can’t do this via a filter since ‘Table’ is an entity and not a value – instead I need some M code to create a new column which does contain values.
data:image/s3,"s3://crabby-images/d8142/d8142e3dc08f3b59ba967147c9c0756680414593" alt=""
The M code I have used is
let
Source = Folder.Contents("C:\Users\kathr\OneDrive\Documents\PQ_StandardExpenses"),
FileType =Table.AddColumn(Source,"Folder",each Value.Is([Content],type table))
in
FileType
This creates a Boolean – a column which is TRUE or FALSE – in this case, it is TRUE if Content contains a table. I will look at the function Value.Is() in more detail in next week’s blog.
data:image/s3,"s3://crabby-images/11e58/11e58a9787221784c036185b8a54a01b31dd8f64" alt=""
I can then filter on Folder:
data:image/s3,"s3://crabby-images/62e03/62e035ccfe74b493758ed44f1d5df5eeef253a56" alt=""
and I am left with my filtered result, viz.
data:image/s3,"s3://crabby-images/9106b/9106b5abdd09aefc1f132a32400856f12413e31d" alt=""
Come back next time for more ways to use Power Query!