Power Query: a Function Function
6 September 2017
Welcome to our Power Query blog. Today I look at an easy way to view and test M code functions against data in my workbook.
My blog comes of age this week as it hits the big 4-0! I am feeling quite empowered, so that gives me an idea! In M-Powered, I described how to get to a description of the functions that can be used in M code to manipulate data by accessing the Microsoft help pages. There is however another way to get to the functions. Let me show you.
I begin with a blank query:
data:image/s3,"s3://crabby-images/c8b4e/c8b4e5408c3ee3b061f0e84625820f81eb736f90" alt=""
In the formula bar I enter the formula
=#shared
data:image/s3,"s3://crabby-images/2be8c/2be8c4f21365bffb38df3e5a6c009b53c5a21d2b" alt=""
The screen displays a list of elements in my workbook, and a list of functions available to me. In order to investigate further, I choose the option at the top left of the screen in the ‘Convert’ section, namely ‘Into Table’ (feel free to select something else if you can find it!):
data:image/s3,"s3://crabby-images/7df76/7df76d4ab6aa87229a57a8c65c5f7316aedcc98f" alt=""
The top rows show the queries in my workbook, and if I click on ‘Table’ next to one of them I can see the data in my query:
data:image/s3,"s3://crabby-images/17362/17362ea3aff9f47df93d124f7193600ea83729ec" alt=""
Going back to my list of functions, further down the rows I can see the List.Range function that I used in One Route to a Running Total. I try clicking on the ‘Function’ label next to it:
data:image/s3,"s3://crabby-images/c4d56/c4d565391e5ae6e2e6d7b97663032834257f9346" alt=""
In the background, I can see a full description of the List.Range function, and I also have the option of trying out the function on one of my columns. Clicking the ‘Choose Column’ button accesses another screen:
data:image/s3,"s3://crabby-images/a6055/a60552a8a576052c96c783a91b15ab512d21f772" alt=""
I can choose any query in my workbook to try out the function.
data:image/s3,"s3://crabby-images/1a3b3/1a3b3bd46fcd246e2f3ec4af3cec21e857c59705" alt=""
Once I pick a query, I can see all the columns in that query and the first few rows of data. I choose List as the column to use.
data:image/s3,"s3://crabby-images/224ff/224ff8267067af1948823ba6902de491ecb94b67" alt=""
I am taken back to the previous pop-up screen so that I can enter the offset and count if I wish. I choose an offset of 1 and a count of 3 and continue.
data:image/s3,"s3://crabby-images/e8890/e8890f9c6ce510fbd03fe3f2cb07a9401ae94743" alt=""
I have tested the List.Range function and it has come back with the first three entries in my list column.
I can also call the #shared function from within a query to test out a function (or look for one). I choose to add a step by clicking the fx button in the Ribbon above my Query1, as shown below:
data:image/s3,"s3://crabby-images/3cf1b/3cf1b1bf1725632a5ca4ceb1790c502a89c707da" alt=""
I choose to add my ‘#shared’ step:
data:image/s3,"s3://crabby-images/d0156/d0156b6f9ba1bc7d1405d443655aa7df916812fc" alt=""
I can see the same record as before and I can go on to try out a function against any data in my workbook. This time let’s try something different:
data:image/s3,"s3://crabby-images/824c7/824c73237e3b68846b4ce3484d808da43144bbfe" alt=""
Having acquired my answer, I can then continue with my query
data:image/s3,"s3://crabby-images/7de2e/7de2e4982a2fe9d6d0c2257c5d21d34d38bb80eb" alt=""
If I delete the extra steps I have created, from ‘Custom1’ to ‘InvokedFunctionValue’ I can get back to my original query.
data:image/s3,"s3://crabby-images/73d26/73d26bdc812250af2729a234826d4dd7a676f73b" alt=""
Want to read more about Power Query? A complete list of all our Power Query blogs can be found here. Come back next time for more ways to use Power Query!