Power Query: Are Any of Them on the Table?
26 June 2019
Welcome to our Power Query blog. Today, I revisit the data I looked at last week to extend one of my solutions.
Last week, I checked if a company had been contacted by any of my salespeople, using 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 used this function to see if any of my salespeople had contacted a company.
data:image/s3,"s3://crabby-images/603fd/603fd25035444d106c0260f2b6e4ebe9de16dde7" alt=""
The M code I have used is:
= Table.ContainsAny([Contacts], {[Name="John"], [Name="Mary"], [Name= "Paul"], [Name="Newbie"]})
When I pressed OK, I saw which companies had any contact with my employees:
data:image/s3,"s3://crabby-images/9c5ab/9c5ab0fd127f8ea2c59b6a013a6bcbd30fea79ad" alt=""
This showed me that all the companies have been contacted, even if some companies had been contacted more than once. However, whilst it’s feasible to use individual names for a small group of salespeople, if I had a larger imaginary company, then I would want a way of doing this without using specific names.
data:image/s3,"s3://crabby-images/fe0ef/fe0ef7d0bb796473a68c22190ea5abd0e7e9e828" alt=""
There are a couple of ways I could do this for my data.
I go back to the query I created in Power Query: Is it on the Table? which checked if any of my named people had contacted each company.
data:image/s3,"s3://crabby-images/9c5ab/9c5ab0fd127f8ea2c59b6a013a6bcbd30fea79ad" alt=""
One way I can approach this is to amend my M code check a different column. I started with the M
= Table.ContainsAny(Contacts, {[Name="John"], [Name="Mary"], [Name= "Paul"], [Name="Newbie"]})
I can change this to:
= Table.ContainsAny(Contacts, {Mail = “Yes”})
data:image/s3,"s3://crabby-images/887df/887df0c5d7f4b087284f2a49f084e8e16a6b1deb" alt=""
I can see that all my companies have been contacted.
This does leave the question of the best way to see if the companies were contacted by a specified list of people, without actually listing them. If I try and use Table.ContainsAny(), I would need to generate a list of records, which is tricky to format. An easier way is to create a table of salespeople, and then use a ‘Salespeople’ query to link to my data and get the answer that way.
data:image/s3,"s3://crabby-images/86824/86824d46665ea2c2e898d2fc1759d5512f86422d" alt=""
I have created a table of salespeople (and have left out Newbie) with the goal of checking if the companies have been contacted by the people in this table.
data:image/s3,"s3://crabby-images/73d3c/73d3cfea174783b8f753f06a72239371bad45210" alt=""
I merge my queries, taking the defaults and matching on Name.
data:image/s3,"s3://crabby-images/beb8f/beb8f6163fb12497e70a246a18a749ae9f8fe18e" alt=""
Then, I expand my data.
data:image/s3,"s3://crabby-images/7e91b/7e91bab5b5a2f6ab3fbd1871edf95a783f9a8318" alt=""
I can now create a custom column which will indicate if the company has been contacted by one of my main salespeople.
data:image/s3,"s3://crabby-images/3a8c6/3a8c66b213a3ef74d54a909525d791d5d5d967be" alt=""
I can now rename my column and remove the temporary column.
data:image/s3,"s3://crabby-images/839c9/839c92e1fc5f59400bede65dbce68cd45729bdb8" alt=""
I can now see who has been contacted by my main team.
Come back next time for more ways to use Power Query!