User Tools

Site Tools


microsoft_excel:macros:compare:compare_rows

Microsoft Excel - Macros - Compare - Compare Rows

Sub CompareRows()
    Dim Row1 As Range
    Dim Row2 As Range
 
  'Prompt user for the first row range to compare...
  '----------------------------------------------------
    Set Row1 = Application.InputBox("Select First Row to Compare", Type:=8)
 
    'Check that the range they have provided consists of only 1 row...
    If Row1.Rows.Count > 1 Then
 
      Do Until Row1.Rows.Count = 1
 
        MsgBox "You can only select 1 row"
        Set Row1 = Application.InputBox("Select First Row to Compare", Type:=8)
 
      Loop
 
    End If
 
  'Prompt user for the second row range to compare...
  '----------------------------------------------------
    Set Row2 = Application.InputBox("Select Second Row to Compare", Type:=8)
 
    'Check that the range they have provided consists of only 1 row...
    If Row2.Rows.Count > 1 Then
 
      Do Until Row2.Rows.Count = 1
 
        MsgBox "You can only select 1 row"
        Set Row2 = Application.InputBox("Select Second Row to Compare", Type:=8)
 
      Loop
 
    End If
 
 
  'Check both row ranges are the same size...
  '---------------------------------------------
  If Row2.Columns.Count <> Row1.Columns.Count Then
 
    Do Until Row2.Columns.Count = Row1.Columns.Count
 
      MsgBox "The second row must be the same size as the first"
      Set Row2 = Application.InputBox("Select Second Row to Compare", Type:=8)
 
    Loop
 
  End If
 
  'If entire rows have been selected (e.g. $AEmbarrassedA), limit the range sizes to the
  'UsedRange of the active sheet. This stops the routine checking the entire sheet
  'unnecessarily.
  '-------------------------------------------------------------------------------
  If Row1.Columns.Count = 16384 Then
 
    Set Row1 = Range(Row1.Cells(1), Row1.Cells(ActiveSheet.UsedRange.Columns.Count))
    Set Row2 = Range(Row2.Cells(1), Row2.Cells(ActiveSheet.UsedRange.Columns.Count))
 
  End If
 
 
  'Perform the comparison and set cells that are the same to yellow
  '----------------------------------------------------------------
  Dim intCell As Long
 
  For intCell = 1 To Row1.Columns.Count
 
    If Row1.Cells(intCell) <> Row2.Cells(intCell) Then
 
      Row1.Cells(intCell).Interior.Color = vbYellow
      Row2.Cells(intCell).Interior.Color = vbYellow
 
    Else
 
      Row1.Cells(intCell).Interior.Color = vbWhite
      Row2.Cells(intCell).Interior.Color = vbWhite
 
    End If
 
  Next
 
End Sub
 
Sub CompareRows2(Row1 As Range, Row2 As Range)
 
  Dim intCell As Long
 
  For intCell = 1 To Row1.Columns.Count
 
    On Error Resume Next
    If Row1.Cells(intCell) <> Row2.Cells(intCell) Then
 
'        Row1.Cells(intCell).Interior.Color = vbYellow
        Row2.Cells(intCell).Interior.Color = vbYellow
 
    Else
 
'        Row1.Cells(intCell).Interior.Color = vbWhite
        Row2.Cells(intCell).Interior.Color = vbWhite
 
    End If
 
  Next
 
End Sub
 
Sub CheckRowSame()
'
' CheckRowSame Macro
'
  Dim Row1 As Range
  Dim Row2 As Range
 
  Dim Resource1 As String
  Dim Resource2 As String
 
  Dim Columns As Integer
  Dim ColumnLetter As String
 
    Application.Goto Range("A2"), True
    ActiveCell.Offset(1, 0).Range("A1").Select
    Resource1 = ActiveCell.Text
 
    Columns = ActiveSheet.UsedRange.Columns.Count
    If Columns = 3 Then ColumnLetter = "C"
    If Columns = 4 Then ColumnLetter = "D"
    If Columns = 5 Then ColumnLetter = "E"
    If Columns = 6 Then ColumnLetter = "F"
    If Columns = 7 Then ColumnLetter = "G"
    If Columns = 8 Then ColumnLetter = "H"
    If Columns = 9 Then ColumnLetter = "I"
    If Columns = 10 Then ColumnLetter = "J"
    If Columns = 11 Then ColumnLetter = "K"
    If Columns = 12 Then ColumnLetter = "L"
    If Columns = 13 Then ColumnLetter = "M"
    If Columns = 14 Then ColumnLetter = "N"
    If Columns = 15 Then ColumnLetter = "O"
    If Columns = 16 Then ColumnLetter = "P"
    If Columns = 17 Then ColumnLetter = "Q"
    If Columns = 18 Then ColumnLetter = "R"
    If Columns = 19 Then ColumnLetter = "S"
    If Columns = 20 Then ColumnLetter = "T"
    If Columns = 21 Then ColumnLetter = "U"
    If Columns = 22 Then ColumnLetter = "V"
    If Columns = 23 Then ColumnLetter = "W"
    If Columns = 24 Then ColumnLetter = "X"
    If Columns = 25 Then ColumnLetter = "Y"
    If Columns = 26 Then ColumnLetter = "Z"
 
    Do While Resource1 <> ""
        Set Row1 = Range("A" & ActiveCell.Row, ColumnLetter & ActiveCell.Row)
'        Resource1 = ActiveCell.Text
 
        ActiveCell.Offset(1, 0).Range("A1").Select
        Resource2 = ActiveCell.Text
        Set Row2 = Range("A" & ActiveCell.Row, ColumnLetter & ActiveCell.Row)
 
        If Resource1 = Resource2 Then
            Call CompareRows2(Row1, Row2)
            ActiveCell.Offset(1, 0).Range("A1").Select
            If Resource1 = ActiveCell.Text Then
                ActiveCell.Offset(-1, 0).Range("A1").Select
            Else
                Resource1 = ActiveCell.Text
            End If
        Else
            ActiveCell.Offset(1, 0).Range("A1").Select
            If Resource2 = ActiveCell.Text Then
                Resource1 = ActiveCell.Text
                ActiveCell.Offset(-1, 0).Range("A1").Select
            Else
                Resource1 = ActiveCell.Text
            End If
        End If
    Loop
 
    Application.Goto Range("A2"), True
 
End Sub
microsoft_excel/macros/compare/compare_rows.txt · Last modified: 2021/08/04 15:03 by peter

Donate Powered by PHP Valid HTML5 Valid CSS Driven by DokuWiki