Celebrate National IT Professionals Day with 3 months of free Premium Membership. Use Code ITDAY17

x
?
Solved

Compare two columns in two worksheets, copy like data to third sheet and mismatched data to fourth and fifth sheet

Posted on 2016-08-04
13
Medium Priority
?
46 Views
Last Modified: 2016-08-27
I need VBA to compare values in column B and column A in worksheet 1 to values in column B and column A in worksheet 2. If the same values are present in both columns of both worksheets, copy the full rows into worksheet 3. If values in both columns are present in worksheet 1 but not in worksheet 2, copy the full rows into worksheet 4. If values in both columns are present in worksheet 2 but not in worksheet 1, copy the full rows into worksheet 5.
0
Comment
Question by:Jamie M
[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
  • 7
  • 5
13 Comments
 
LVL 32

Expert Comment

by:Subodh Tiwari (Neeraj)
ID: 41742881
Can you upload a small sample workbook with max 25-30 rows of data to know the sheet structure?
Haw many rows of data is there on both the sheets in actual workbook?
0
 

Expert Comment

by:Davidjevans
ID: 41742964
Have you tried the MS Excel add-in "Fuzzy Lookup"?
0
 

Author Comment

by:Jamie M
ID: 41743993
Neeraj

Thank you for your help! I have attached a small example of what the workbook would look like - I only put data in Columns A and B of Sheet1 and Sheet2 but my actual workbook will have several columns filled. The number of rows in each sheet will be different each day.

Jamie
0
Industry Leaders: 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!

 

Author Comment

by:Jamie M
ID: 41743994
Davidjevans

No I have not tried Fuzzy Lookup but I will check it out today!  Thank you,

Jamie
0
 
LVL 32

Expert Comment

by:Subodh Tiwari (Neeraj)
ID: 41744039
Hi Jamie,

You forgot to attache the sample workbook.
0
 

Author Comment

by:Jamie M
ID: 41744105
Neeraj...  

hmmm... I attached it but I think I forgot to actually upload it  :)  Sorry!  Here it is
Example-Workbook.xlsx
0
 
LVL 32

Expert Comment

by:Subodh Tiwari (Neeraj)
ID: 41744217
In case 2 and 3, copy the values from which worksheet into worksheet4 and worksheet5?
Also does Sheet1 not have headers?
0
 
LVL 32

Expert Comment

by:Subodh Tiwari (Neeraj)
ID: 41744285
Please try this...

In the attached, click the button on Sheet1 to run the code.
If you have any issue with downloading and opening the attached workbook due to a temporary bug in the forum, first download and save it on your system and then open it.

Sub MatchAndCopy()
Dim x, y, Arr3(), Arr4(), Arr5()
Dim dict As Object, dict2 As Object
Dim i As Long, j As Long, k As Long, l As Long, m As Long

Set dict = CreateObject("Scripting.Dictionary")
Set dict2 = CreateObject("Scripting.Dictionary")

x = Sheet1.Range("A1").CurrentRegion.Value
y = Sheet2.Range("A1").CurrentRegion.Value

ReDim Preserve Arr3(1 To UBound(x, 1), 1 To UBound(x, 2))
ReDim Preserve Arr4(1 To UBound(x, 1), 1 To UBound(x, 2))
ReDim Preserve Arr5(1 To UBound(y, 1), 1 To UBound(y, 2))

Sheet3.Cells.Clear
Sheet4.Cells.Clear
Sheet5.Cells.Clear
For i = 1 To UBound(x, 1)
    dict.Item(x(i, 1) & x(i, 2)) = ""
Next i

For i = 1 To UBound(y, 1)
    dict2.Item(y(i, 1) & y(i, 2)) = ""
Next i

For j = 1 To UBound(y, 1)
    If dict.exists(y(j, 1) & y(j, 2)) Then
        k = k + 1
        Arr3(k, 1) = y(j, 1)
        Arr3(k, 2) = y(j, 2)
    ElseIf Not dict.exists(y(j, 1) & y(j, 2)) Then
        l = l + 1
        Arr5(l, 1) = y(j, 1)
        Arr5(l, 2) = y(j, 2)
    End If
Next j
k = 0
For j = 1 To UBound(x, 1)
    If Not dict2.exists(x(j, 1) & x(j, 2)) Then
        k = k + 1
        Arr4(k, 1) = x(j, 1)
        Arr4(k, 2) = x(j, 2)
    End If
Next j
Sheet3.Range("A1").Resize(UBound(Arr3), 2).Value = Arr3
Sheet4.Range("A1").Resize(UBound(Arr4), 2).Value = Arr4
Sheet5.Range("A1").Resize(UBound(Arr5), 2).Value = Arr5
Set dict = Nothing
MsgBox "Task Completed.", vbInformation, "Done!"
End Sub

Open in new window

Example-Workbook.xlsm
0
 

Author Comment

by:Jamie M
ID: 41746850
Neeraj-

This works great to separate everything! However, my real data has several columns and the code only places columns A and B into the three new worksheets... I need the entire row, all columns, to be transferred. Also, all five sheets should have matching headers. Sheet one should have the same headers as sheet two etc.  It looks like the code is placing headers only in sheet five and I must have forgotten them on sheet one.

Jamie
0
 
LVL 32

Accepted Solution

by:
Subodh Tiwari (Neeraj) earned 2000 total points (awarded by participants)
ID: 41747057
Please find the attached with the tweaked code.
Sheet3, Sheet4 and Sheet5 contain the headers in advance and the data will be pasted below those headers.
Example-Workbook-v2.xlsm
0
 

Author Comment

by:Jamie M
ID: 41747139
Neeraj-

Your fix was perfect!  Thank you so much!

Jamie
0
 
LVL 32

Expert Comment

by:Subodh Tiwari (Neeraj)
ID: 41747161
You're welcome Jamie! Glad to help.
0
 
LVL 32

Expert Comment

by:Subodh Tiwari (Neeraj)
ID: 41772810
The best chosen answer resolved the question.
0

Featured Post

Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

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

This tutorial explains how to create a series of drop-down lists that are dependent upon prior selections to guide (“force”) the user to make the correct selection and reduce data errors within Microsoft Excel. Excel 2010 was used for this tutorial;…
This article describes how to use a set of graphical playing cards to create a Draw Poker game in Excel or VB6.
The viewer will learn how to use a discrete random variable to simulate the return on an investment over a period of years, create a Monte Carlo simulation using the discrete random variable, and create a graph to represent the possible returns over…
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 …

730 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