Power Query: Is it on the Table?
19 June 2019
Welcome to our Power Query blog. Today, I delve into the Table.Contains() M functions.
I have a list of companies that my imaginary salespeople have interacted with recently. I have linked to a ‘Contacts’ table, and I want to use that to find out which companies John has contacted.
data:image/s3,"s3://crabby-images/0f95c/0f95cc4742e257a9af5ee24e22fa3a4168506c0f" alt=""
I can expand the table information, but even for this small example, that would create extra rows I don’t need to see. There is another way:
Table.Contains table as table, row as record, optional equationCriteria as any) as logical
This determines whether a record appears as a row in the table.
Table.Contains is similar to List.Contains, which I previously looked at in Power Query: Words are Key.
I add a custom column from the ‘Add Column’ tab.
data:image/s3,"s3://crabby-images/a7e18/a7e18a9e3c545501ca84cf631a98d6df70b43580" alt=""
The M code I have used is:
= Table.Contains([Contacts], [Name="John"])
In order to look for “John”, I need to enter the record that would feature the name John. When I click OK, a new column is created:
data:image/s3,"s3://crabby-images/f086e/f086e17481b21bdf44da6d884ff30650c8b3ec21" alt=""
I can now expand the Contacts column to check my results.
data:image/s3,"s3://crabby-images/80190/8019055c0ed246f43b60d115dad6ed483b6c9ed0" alt=""
It is harder to read as there are extra rows, but I can see that John has contacted the first three companies.
I can also look at it a different way. Going back to my merged table, I want to see if any of the companies were contacted by John and Mary. To do this, I am going to use Table.ContainsAll():
Table.ContainsAll(table as table, rows as list, optional equationCriteria as any) as logical
This determines whether all of the specified records appear as rows in the table.
In this case, I enter my employee names as a list of records. I can use this function to look for more than one employee contacting (i.e. harassing!) a company.
data:image/s3,"s3://crabby-images/dd39e/dd39ee31ebddd87d60e7b4e5c19c9c2ec018f17e" alt=""
The M code I have used is:
= Table.ContainsAll([Contacts], {[Name="John"], [Name="Mary"]})
When I press OK, I can see who has been contacted by both John and Mary:
data:image/s3,"s3://crabby-images/d5a25/d5a2520ed6a097ada0ca647e8b98b51026c7af89" alt=""
Tent Time USA appears to have been contacted by both of them, and I can expand the table to verify this.
data:image/s3,"s3://crabby-images/6e228/6e22803f4d48c64fdc882cd16654f62ffefe8ddc" alt=""
I can see that the company were indeed contacted by both salespeople.
I can also check if a company has been contacted by any of my salespeople, to do this I use Table.ContainsAny:
Table.ContainsAny(table as table, rows as list, optional equationCriteria as any) as logical
This determines whether any of the specified records appear as rows in the table.
I can use this function to see if any of my salespeople have contacted a company.
data:image/s3,"s3://crabby-images/c9a00/c9a004aa0e82aa2f3efb4f330a4674489c53f7c5" alt=""
The M code I have used is:
= Table.ContainsAny([Contacts], {[Name="John"], [Name="Mary"], [Name= "Paul"], [Name="Newbie"]})
When I press OK, I will see which companies have had any contact with my employees:
data:image/s3,"s3://crabby-images/3dc15/3dc156cf7598114f6e6c0b1003b4d46ee4ea8401" alt=""
Some good news, all the companies have been contacted, even if some companies have been contacted more than once!
Come back next time for more ways to use Power Query!