Power Query: New Year Function
6 January 2021
Welcome to our Power Query blog. This week, I look at an example using custom functions.
I have some supplier data:
data:image/s3,"s3://crabby-images/48182/48182750692fd7d829f1123ca5ff0b3490297e9b" alt=""
I intend to find out the percentage of the total sales of each tent per customer, and show it alongside the transactions. I start by extracting my data to Power Query using ‘From Table’ in the ‘Get & Transform’ section of the Data tab.
data:image/s3,"s3://crabby-images/8e396/8e396aa071d699199e8e134dfb776b0a537abbeb" alt=""
I accept the defaults.
data:image/s3,"s3://crabby-images/17de9/17de98aab62ac47fc1fea9b88bf29bf5d407cc0c" alt=""
I will need two copies of this query, so I can right-click on my query in the Queries pane and choose Duplicate.
data:image/s3,"s3://crabby-images/c5c7f/c5c7f9f93ddac385bdcf5e2778d830c3447ba10f" alt=""
I can now rename my queries. One is going to be my ‘Supplier Rentals’ query and one is going to be a function which I will call fnSupplierTotal.
data:image/s3,"s3://crabby-images/f66eb/f66eb90b38fa7de0b106721eaca4f5123861927d" alt=""
In fnSupplierTotals, I delete the ‘Changed Type’ step.
data:image/s3,"s3://crabby-images/0f138/0f138253a39c06990c8edc1678e262d1bc070f80" alt=""
In the Transform tab, I choose ‘Group By’.
data:image/s3,"s3://crabby-images/21b70/21b701219e7cf1dcd2f8d0d19cd397774d6acbc0" alt=""
I filter on Supplier and choose just ‘Tents R Us’ (any supplier would do; I just need the syntax).
data:image/s3,"s3://crabby-images/ef076/ef076e40669067ac50ae2b13c1b9b7f61226e543" alt=""
I can now apply this to get my query.
data:image/s3,"s3://crabby-images/79d35/79d3535852a390782b3d1c598cc5e9397c111cd7" alt=""
In the Advanced Editor, which I accessed from the Home tab, I can see the current M code:
data:image/s3,"s3://crabby-images/efae6/efae64abaf0e9444539fea4a020fa60149cade16" alt=""
The M code is:
let
Source = Excel.CurrentWorkbook(){[Name="Table1"]}[Content],
#"Grouped Rows" = Table.Group(Source, {"Supplier"}, {{"Supplier Total", each List.Sum([Rentals]), type number}}),
#"Filtered Rows" = Table.SelectRows(#"Grouped Rows", each ([Supplier] = "Tents R Us"))
in
#"Filtered Rows"
Since this is now going to be a function, I start with a line defining my parameters.
(sourceTable as table, supplierName as text) =>
Since I am passing in the source, I don’t need the source line, so I can delete it.
That means the #"Grouped Rows" step that referred to ‘Source’ must now use sourceTable instead. I also need to change ‘Tents R Us’ to my supplier parameter.
I can also tweak the code to return a value instead of a table with the value in by adding a step:
#"SupplierTotal" = Record.Field(#"Filtered Rows"{0},"Supplier Total")
(Record.Field is a Power Query function which returns single value from a column.)
My M code is now:
(sourceTable as table, supplierName as text)=>
let
#"Grouped Rows" = Table.Group(sourceTable, {"Supplier"}, {{"Supplier Total", each List.Sum([Rentals]), type number}}),
#"Filtered Rows" = Table.SelectRows(#"Grouped Rows", each ([Supplier] = supplierName)),
#"SupplierTotal" = Record.Field(#"Filtered Rows"{0},"Supplier Total")
in
#"SupplierTotal"
data:image/s3,"s3://crabby-images/614ec/614ec344c2018ef0ea403fb6d483a4498c61412c" alt=""
My function is ready to use. I can test it by pointing at my ‘Supplier Rentals’ query and choosing ‘Tents R Us’.
data:image/s3,"s3://crabby-images/52ff9/52ff95cf8dcb15107b776669d49b85246022bd83" alt=""
This should give me the total for ‘Tents R Us’.
data:image/s3,"s3://crabby-images/177fd/177fd6a3ca4bc0cb8de8f98133a0dc798d3aad33" alt=""
So far, so good.
Now, I go back to the ‘Supplier Rentals’ Query.
data:image/s3,"s3://crabby-images/66851/668519024e207b06e3412ce950d3118ce9f6594b" alt=""
I am adding a custom column from the ‘Add Column’ tab.
data:image/s3,"s3://crabby-images/3ece2/3ece2d0cc51974d9a8015292008bd0f16c6cb304" alt=""
The M code I have used is:
= [Rentals]/fnSupplierTotal(Source, [Supplier])
I am dividing the Rentals value by the total for the Supplier, as provided by my function.
data:image/s3,"s3://crabby-images/32f34/32f34afb8489307f41a7d2baf3159c6f379de226" alt=""
To show this as a percentage I can just change the Data Type to percentage from the Transform tab.
data:image/s3,"s3://crabby-images/ac9fc/ac9fcce1917b4d98ab1a46542e02fd290e6d6dec" alt=""
Come back next time for more ways to use Power Query!