Identifying relations
- Subscribe to RSS Feed
- Mark Topic as New
- Mark Topic as Read
- Float this Topic for Current User
- Bookmark
- Subscribe
- Mute
- Printer Friendly Page
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Notify Moderator
Hi,
I have hit a roadblock while trying to build a logic. Hope can get some some solution to my problem.
I am working with a complex data which contains the relation between a parent customer and a child customer and vice versa. The linkage file has got all possible combinations of the customers. The ask is to group or flag all the related customers separately. Below is a mock up of the sample data and the scenario is explained.
The aim to group all the related ones under the "Synthetic Group" column.
Parent Customer | Child Customer | Synthetic Group |
100 | 101 | a1 |
100 | 102 | a1 |
100 | 103 | a1 |
100 | 104 | a1 |
126 | 100 | a1 |
127 | 100 | a1 |
128 | 100 | a1 |
101 | 178 | a1 |
101 | 179 | a1 |
101 | 180 | a1 |
101 | 180 | a1 |
105 | 678 | a2 |
105 | 567 | a2 |
567 | 221 | a2 |
567 | 222 | a2 |
679 | 302 | a2 |
567 | 105 | a2 |
As we can see in the picture, on sorting the Parent Customer column, whenever a new parent customer is identified, we are looking for all its relations in the child customer column and grouping them. Again the child customers that we are getting are being looked in the parent customer and child customer columns and if any relation is found we are assigning them in the same group.
Like parent customer 100 is directly related to child customers 101,102,103,104. Now we again for these child customers in the parent customer and child customer column and find for any new connections and if found we group them. This process would go on till there are no further relations of a group.
So the ide a is club together all the parent and child customers who might be linked any which way possible and create this synthetic group.
Needless to say this is just a sample. There are around 1 million rows in the main dataset
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Notify Moderator
You might check out the "Make Group" tool - point the 1st Key to the Parent column, and the 2nd to the Child column. This should sort your data into two columns, with "Group" containing 1 of the items that can be used as your overall group (or "synthetic group" in your case, and then the second column containing all the values from both Parent and Child that belong to that group. The format of the data is a little different, but I believe it would be fairly straightforward to use the Make Group result as the basis for a lookup table that you could then use to append the groups back to your original list, for example, to get something that looks like your original desired output.
Note - it actually looks like there are 3 groups - I think members 302 & 679 should be in their own group, rather than included in a2 as in your example (second to last row), since they don't appear in any other matching combos of parent/child?
Hope that helps!
NJ
data:image/s3,"s3://crabby-images/76987/7698732fe1a2db7e425565f43261054960126881" alt=""