Solved

Identify similar groups of numbers

Posted on 2013-02-04
7
211 Views
Last Modified: 2013-02-04
I have sets of six numbers.

I have selected all possible groups of three from each set of six numbers.

I have to cross examine between sets in order to identify where there are similarities.

This means if I find a set of three numers (eg 15,60,75) in one set of six numbers (eg 15,20,50,60,65,75), I have to inspect all other sets of six numbers to try and find the same.

I have to do this for all possible sets of three numbers from all sets of six.

on the worksheet that I have attached, I have separated out the "sets of three" for visual purposes, as I also have to be able to look through this list like this.
I would like to colour the cells of similar "sets of three numbers" the same colour. But each set pair found after that would require a different colour to be applied.

Would it be possible (without altering the cells of the original sets of six) to go through all of these sets of three numbers and identify other identical sets ?
select-groups-of-3.xls
0
Comment
Question by:MichaelGlancy
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 4
  • 3
7 Comments
 
LVL 47

Expert Comment

by:Martin Liss
ID: 38851640
Looking at the data it seems that all sets of three have a duplicate since rows 3 and 4 are the same as 7 and 8. So if you run this code against that data all the sets of 3 will be highlighted, but maybe your real data is different.


Sub IdentifyDuplicates()

Dim lngLastRow As Long
Dim lngLastColumn As Long
Dim lngRow As Long
Dim lngCol As Long
Dim DupeSets() As Sets
Dim strSet As String
Dim lngFind As Long
Dim bFound As Boolean

ReDim DupeSets(0)
lngLastRow = Range("A65536").End(xlUp).Row
lngLastColumn = Cells.Find("*", SearchOrder:=xlByColumns, LookIn:=xlValues, SearchDirection:=xlPrevious).Column

For lngRow = 3 To lngLastRow
    If Cells(lngRow, 1) <> "" Then
        For lngCol = 9 To lngLastColumn Step 4
            strSet = Cells(lngRow, lngCol) & Cells(lngRow, lngCol + 1) & Cells(lngRow, lngCol + 2)
                    bFound = False

            For lngFind = 0 To UBound(DupeSets)
                If strSet = DupeSets(lngFind).strCells Then
                    bFound = True
                    Exit For
                End If
            Next
            If bFound Then
                Range(DupeSets(lngFind).strAddr).Interior.Color = vbYellow
                Range(DupeSets(lngFind).strAddr).Offset(0, 1).Interior.Color = vbYellow
                Range(DupeSets(lngFind).strAddr).Offset(0, 2).Interior.Color = vbYellow
                Range(Cells(lngRow, lngCol), Cells(lngRow, lngCol + 2)).Interior.Color = vbYellow
            Else
                DupeSets(UBound(DupeSets)).strCells = strSet
                DupeSets(UBound(DupeSets)).strAddr = Cells(lngRow, lngCol).Address
                ReDim Preserve DupeSets(UBound(DupeSets) + 1)
            End If

        Next
    End If
Next
End Sub

Open in new window

0
 

Author Comment

by:MichaelGlancy
ID: 38851654
thankyou I will try that. the data I gave you was a sample, purposely duplicated for demonstration. thanks again, checking now.
0
 

Author Comment

by:MichaelGlancy
ID: 38851674
I get Error

cant execute code in break mode

Dim DupeSets() As Sets is highlighted

can you help as I am new user thankyou
0
Business Impact of IT Communications

What are the business impacts of how well businesses communicate during an IT incident? Targeting, speed, and transparency all matter. Find out more in this infographic.

 

Author Comment

by:MichaelGlancy
ID: 38851675
and

user defined type not defined
0
 
LVL 47

Accepted Solution

by:
Martin Liss earned 500 total points
ID: 38851708
Sorry, I left out some code when I posted.

I've attached a workbook that contains the code. Look in Module1. IdentifyDuplicates is a macro to which I have assigned ctrl+z, so if you enter ctrl+z from the sheet the macro will execute. You could also go into the code environment select the macro and press F5.
select-groups-of-3.xls
0
 

Author Closing Comment

by:MichaelGlancy
ID: 38851851
does the job perfectly
0
 
LVL 47

Expert Comment

by:Martin Liss
ID: 38851972
Thanks and I'm glad I was able to help.

Your accepting my answer as the solution put me over the 1,000,000 point mark! Thank you.

Marty - MVP 2009 to 2012
0

Featured Post

Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
A WS within a WS 11 38
Microsoft exchange 2010 issue 1 17
Excel not storing numeric string correctly 5 35
need help to look for 16 39
When you upgrade from Windows 8 to 8.1 or to Windows 10 or if you are like me you are on the Insider Program you may find yourself with many 450MB recovery partitions.  With a traditional disk that may not be a problem but with relatively smaller SS…
Do you use a spreadsheet like Microsoft's Excel?  Have you ever wanted to link out to a non excel file on your computer or network drive?  This is the way I found to do it!
The viewer will learn how to create two correlated normally distributed random variables in Excel, use a normal distribution to simulate the return on different levels of investment in each of the two funds over a period of ten years, and, create a …
This Micro Tutorial will demonstrate how to use a scrolling table in Microsoft Excel using the INDEX function.

739 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question