Power Query: Binary Function
20 January 2021
Welcome to our Power Query blog. This week, I look at using a function when processing binary data.
I have some data for my salespeople. The data is in the form of a collection of Excel files held in one folder. I would like to create a custom function that I can run against this data before I combine the files into one query.
data:image/s3,"s3://crabby-images/4abd5/4abd55772aaac43330bbb6d13af6a0680a172240" alt=""
I start in the ‘Get & Transform’ section of the Data tab, where I choose to create a ‘New Query’. From the dropdown, I can select ‘From File’ and then ‘From Folder’.
data:image/s3,"s3://crabby-images/7dc24/7dc24be73bf4b3dffcdaae54324953e3655e64b6" alt=""
I select the folders location and view the files. I choose to ‘Transform Data’.
data:image/s3,"s3://crabby-images/439df/439df3b7c5c5e8b89e6f06183dd7d067218792cc" alt=""
I right-click on the first value in the Content column.
data:image/s3,"s3://crabby-images/a5ac5/a5ac5d1d56819168c29567dc753cb9ca357403a1" alt=""
I am going to ‘Add as New Query’.
data:image/s3,"s3://crabby-images/85fd8/85fd878a06c87191986d6922d2141b4a9de23bcd" alt=""
This has created a new query which points at my first Excel file, that just happens to be Derek’s. I rename my query Sample_Expenses.
data:image/s3,"s3://crabby-images/1b8be/1b8be1f425aba8807fc7b310522a6fc2249c03ae" alt=""
I create a new parameter from the Home tab.
data:image/s3,"s3://crabby-images/60385/603857e897c899ba0d004259cf5cde8c43219a6a" alt=""
I call my new parameter Expense_Parameter, and once I choose type Binary. It finds the Sample_Expenses query, and allows me to select it as the default and current value.
data:image/s3,"s3://crabby-images/88141/88141a8f20a28fc1b92ffb6f562212c6046e75e4" alt=""
Once I have created Expense_Parameter, I can right-click it in the Query pane and create a Reference query.
data:image/s3,"s3://crabby-images/711fb/711fb0923606e9ed399f42fe6c9da59be198656f" alt=""
I call my new query Transform_Sample_Expenses.
data:image/s3,"s3://crabby-images/e039e/e039e4a106c8abff1d82d99d99031871d977cdbd" alt=""
I can right-click on my new query and choose ‘Create Function’.
data:image/s3,"s3://crabby-images/bfe25/bfe25516697119fd92d627e09eb2aea5fbfc31fc" alt=""
This function will be linked to my current query, Transform_Sample_Expenses. I call this function Transform_Expenses.
data:image/s3,"s3://crabby-images/ba4ec/ba4ec2edbd77299f345c702bba75341f63db5109" alt=""
My function query expects a binary file as a parameter, and defaults to Derek’s expenses. I can now return to my Transform_Sample_Expenses and make some transformations.
data:image/s3,"s3://crabby-images/4e7f9/4e7f9d314cad1d1894d9fc1c987c9ed32032272a" alt=""
I need to treat my file as an Excel file, so I right-click on the file and choose Excel.
data:image/s3,"s3://crabby-images/3b94b/3b94b9809ed5b3fdd6430531e2a9b0d98b027d1a" alt=""
Since this is the format of all the files in my folder, I continue to transform my data.
data:image/s3,"s3://crabby-images/e2ade/e2ade780feff451c4a2432b58a8d4919ed22ecdf" alt=""
I have removed the first row, expanded the table data, and removed the columns I don’t need. Finally, I fill down on the name. I ‘Close & Load’ from the File tab to save my query.
data:image/s3,"s3://crabby-images/eb9c4/eb9c4f8b4254221011fdbdb06a91f6d7cdf2c47f" alt=""
Back in the query for my Expense folder (‘Expenses Folder Custom’), I can add a column which will call the function I have created.
data:image/s3,"s3://crabby-images/847dd/847ddc4cd79130448b5f59a3cdc185ce04d8c9a2" alt=""
I can select the Transform_Expenses function.
data:image/s3,"s3://crabby-images/1c1bb/1c1bb200fa1b122deaf290c7df13c81a1488f442" alt=""
I am then prompted to enter the binary parameter, and I choose the Content column.
data:image/s3,"s3://crabby-images/1b380/1b3808123de47dd3fab53247bf45d7f3354a3b0b" alt=""
Table data appears in my new column, and if I select one of the lower table values, I can see that I have transformed all of my Excel files, ready to be combined.
data:image/s3,"s3://crabby-images/fde7b/fde7bd579df4f622923f979d18599f6a3bc5a0de" alt=""
I can expand the table data and remove the columns I don’t need.
Come back next time for more ways to use Power Query!