Power Query: Too Random
2 March 2022
Welcome to our Power Query blog. This week, I look at another way of generating random data.
Whilst producing the masterpieces that are Power Query blogs, I often need to generate random data. In Excel, I favour the RANDBETWEEN() function, but there are also functions I can use in Power Query. This week I look at the Number.RandomBetween() function, which is even more like my favourite Excel function, but with an important difference!
This M function has the following syntax:
Number.RandomBetween(bottom as number, top as number) as number
The output is a random number between bottom and top. To show how it is used, I have created a list of numbers from one [1] to 20:
data:image/s3,"s3://crabby-images/5d2df/5d2dfb8524d824c486a54f50d4fdc1818b6cdb4d" alt=""
I then convert the list to a table using the ‘To Table’ option from the Convert section on the Transform tab.
data:image/s3,"s3://crabby-images/9a450/9a4506b9e4b8c1a03e4f8fa7b4f66035cc2dbc5a" alt=""
I now have a table, which means I can add columns:
data:image/s3,"s3://crabby-images/f9552/f9552a138dcb394ec22a70ab82fe5f94910ebc22" alt=""
I choose to add a ‘Custom Column’ from the ‘Add Column’ tab:
data:image/s3,"s3://crabby-images/0519a/0519a9c538b5cad4025f9940022b01490b5e4404" alt=""
I decide I want values between zero [0] and 100:
data:image/s3,"s3://crabby-images/5fd75/5fd75e11aa1681690cc2b344f3a0561f6082684a" alt=""
The M code I have used is:
= Number.RandomBetween(0,100)
This gives me some random values:
data:image/s3,"s3://crabby-images/50ae6/50ae64a08fa36561cdf6fb1f289ed02ddf955e04" alt=""
My first question is whether Number.RandomBetween() is volatile like it’s Excel cousin RANDBETWEEN(). I can check this by refreshing, which I can do using ‘Refresh Preview’ on the Home tab:
data:image/s3,"s3://crabby-images/15204/1520481513a5a12f061cd7f421eafc611a70c684" alt=""
Yes, I have new values. This is important to know as it means I need some way of stabilising the output if I want to use it to generate stable data. In Excel I would Copy and ‘Paste Special’ to keep the values.
To see if something similar is possible, I select RandomBetween and right-click, I have the option to ‘Duplicate Column’:
data:image/s3,"s3://crabby-images/1abd1/1abd1b0ada6c4f5a44cdd18c06278c992c044061" alt=""
This creates another column:
data:image/s3,"s3://crabby-images/0227e/0227ef4fc777c723970bb6d78b52747715886a67" alt=""
Notice that the step ‘Duplicated Column’ does not have a cog icon next to it, but this is misleading. If I refresh data again, I can see if the values change in RandomBetween – Copy:
data:image/s3,"s3://crabby-images/aa02d/aa02d15c6472c533293591d6047b45b6f0730aae" alt=""
RandomBetween – Copy changes to match RandomBetween. Power Query executes all the steps, which means it generates the values for RandomBetween and then takes a copy. Similarly, if I add another step:
data:image/s3,"s3://crabby-images/16534/165349e5a70a43a3e0472270cd69f6066519f9a4" alt=""
Even without refreshing, Number.RandomBetween() is generated for each step. I would need to export to Excel and take a copy from there to get a stable data set.
I will look at another random function next time.
Come back next time for more ways to use Power Query!