Power Query: Going for the Record
7 October 2020
Welcome to our Power Query blog. This week, I put the spotlight on records.
This week, I am going to look at several ways to create a record.
The first and perhaps simplest method is to define a record in M. I have created a record as below:
data:image/s3,"s3://crabby-images/0296d/0296d456f16955ef9016c30169f9d491327ee845" alt=""
The M code I have used is:
= [A = "Kathryn", B = "Record"]
In other words, create a record with two fields, A and B, where A is “Kathryn” and B is “Record”. The result is a record.
data:image/s3,"s3://crabby-images/883ee/883eeb617b1488bcce133d3625348839c77169e5" alt=""
I could use a field name more complex than ‘A’.
data:image/s3,"s3://crabby-images/819c9/819c964925bb38dddeab7d35166e011b5762b557" alt=""
The M code I have used is:
= [this is the first field = "Kathryn", this is the second field = "Record"]
I can do this without surrounding my field name with quotes (“”), and I do not need to include a #, even if there are spaces in my field name.
data:image/s3,"s3://crabby-images/04df3/04df33a33542d75d43172388dea94dbdaa756234" alt=""
I can also create fields of different types without specifying a datatype. The M code I used in the previous screenshot is:
= [this is the first field = "Kathryn", this is the second field which is a number = 1.5]
However, I can’t use the same field name in a record.
data:image/s3,"s3://crabby-images/341a9/341a9f1d09072c1cf4613ceda621f02a7c19aefe" alt=""
I can enter lots of fields in one record though.
data:image/s3,"s3://crabby-images/d04db/d04db533ff31d7eced10b3b8f4faec3616636544" alt=""
The M code I have used is:
= [field 1 = "Kathryn", field 2 = 1.5, field 3 = [inset field 1 = "hello", inset field 2 = "world"]]
In this case, my record has three fields, and the last field is a record, which itself contains two fields.
I can also use M functions to create records. There are many functions which output records, so I will look at just a few of them. I will start with Record.FromTable():
Record.FromTable(table as table) as record
This returns a record from a table containing field names and value names [Name = name, Value = value]. An exception is yielded if the field names are not unique.
data:image/s3,"s3://crabby-images/b33d4/b33d49d4a658a01f66027335d3719cc405c1c0d7" alt=""
I have converted my record to a table, so I should be able to use Record.FromTable() to go back to my original record.
data:image/s3,"s3://crabby-images/7fe2a/7fe2acb8e21a7b72865ddc73d0b756413df0bdc9" alt=""
The M code I enter is:
= Record.FromTable( #"Converted to Table")
where “Converted to Table” is my previous step. I enter this to get the following result:
data:image/s3,"s3://crabby-images/095e0/095e0e9bb1a6d2da3ad55f80ca164b21e2f130ae" alt=""
My table has been converted into a record. I can also create a record from a list using Record.FromList():
Record.FromList(list as list, fields as any) as record
This returns a record given a list of field values and a set of fields. The fields can be specified either by a list of text values, or a record type. An error is generated if the fields are not unique.
data:image/s3,"s3://crabby-images/0950c/0950ce512124356f17278ec20fd4ceb2797f8c7a" alt=""
The M code I have used is:
= Record.FromList(Source, {"Fruit 1","Fruit 2","Fruit 3","Fruit 4"})
This should create a record from my list values and the list of field names that I have specified.
data:image/s3,"s3://crabby-images/6e69e/6e69e781f660c197cfb1281f91850e5c5d5aba27" alt=""
I have the record I expected. I can also use the function Record.Combine():
Record.Combine(records as list) as record
This combines the records in the given records. If the records contain non-record values, an error is returned.
I can combine the records I have created:
data:image/s3,"s3://crabby-images/42b89/42b898ef63db64d89b9e0b9f229a066c9c08e8b0" alt=""
The M code I have used is:
= Record.Combine({Custom1,Query1})
This should combine the record I just created in step Custom1, and the record I created in Query1.
data:image/s3,"s3://crabby-images/cbc03/cbc03e2f33233a722d0ccfdec75c1bf877bb6053" alt=""
The records have been combined to create a new record with seven fields.
There are other Power Query M functions that output records, such as Time.ToRecord():
Time.ToRecord(time as time) as record
This returns a record containing the parts of the given time:
- time: this is a time value for from which the record of its parts is to be calculated.
data:image/s3,"s3://crabby-images/29262/29262b91f72594514c7410b6bb736803cb597333" alt=""
I have created a time 10:15.30, and I am going to convert this into a record.
data:image/s3,"s3://crabby-images/12b81/12b819ae42ee0e2ae3be8c6fd6181f2db237dc0e" alt=""
The M code I have used is:
= Time.ToRecord(Source)
This should convert the source time to a record.
data:image/s3,"s3://crabby-images/97af3/97af3093808722bb02e5a1cc8586224f6118f090" alt=""
A record has been created with field names “Hour”, “Minute”, and “Second”.
Finally, I can get a record by specifying a row of a table:
data:image/s3,"s3://crabby-images/c4fb4/c4fb4286523e749dbf6d6cb6d7aecc11d7e4ea5e" alt=""
I have created a table from my record, and now I can specify just one row of that table to get a new record.
data:image/s3,"s3://crabby-images/e2fc6/e2fc65b83490fd102f757e7a87dfc6e43dc386cb" alt=""
The M code I have used is:
= #"Converted to Table"{4}
This should get the fifth row of my table and present it as a record, since the count starts at 0.
data:image/s3,"s3://crabby-images/27fc2/27fc254fd8151b4dc13cb86be57e26e19a0bb084" alt=""
The fifth row has been converted to a record with field names ‘Name’ and ‘Value’, and field values ‘Field 1’ and ‘Kathryn’ respectively.
Come back next time for more ways to use Power Query!