[英]excel vba sheet comparison using vba in excel and store result in a sheet?
我需要动态选择两个excel工作表的范围,并逐行进行比较,并使用excel VBA宏将其打印在报表中,如true或false。请帮助。VBA宏比较两个Excel文件的所有单元格该链接很有帮助,但我想动态选择范围,还需要在比较表中打印一些TRUE / FALSE。
我确实想将工作表加载到变量数组,然后遍历它们以提高代码的性能。
注意-请假设需要比较的两个工作表都包含相同的行数并进行了排序。
For iRow = LBound(varSheetA, 1) To UBound(varSheetA, 1)
For iCol = LBound(varSheetA, 2) To UBound(varSheetA, 2)
If varSheetA(iRow, iCol) = varSheetB(iRow, iCol) Then
' Cells are identical.
' i want to go to the exact cell in Comparison sheet and type TRUE Else
' Cells are different.
' i want to go to the exact cell in Comparison sheet and type FALSE
End If
Next iCol
Next iRow
这是一个样本。 该示例代码仅在比较选项卡中记录不匹配的数组(i,j)坐标。 您应该对其进行修改以记录所需的任何其他信息:
Sub CompareSheets()
Dim s1 As Worksheet, s2 As Worksheet, s3 As Worksheet
Dim rComp As Range, addy As String
Dim I As Long, J As Long, K As Long
Set s1 = Sheets("Sheet1")
Set s2 = Sheets("Sheet2")
Set s3 = Sheets("comparison")
s1.Select
Set rComp = Application.InputBox(Prompt:="Select range", Type:=8)
addy = rComp.Address
ary1 = rComp
ary2 = s2.Range(addy)
K = 1
For I = LBound(ary1, 1) To UBound(ary1, 1)
For J = LBound(ary1, 2) To UBound(ary1, 2)
If ary1(I, J) = ary2(I, J) Then
Else
s3.Cells(K, 1) = I
s3.Cells(K, 2) = J
K = K + 1
End If
Next J
Next I
End Sub
编辑:
为了回应您的评论,此版本将在比较表中填充TRUE和FALSE:
Sub CompareSheets2()
Dim s1 As Worksheet, s2 As Worksheet, s3 As Worksheet
Dim rComp As Range, addy As String
Dim I As Long, J As Long, K As Long
Set s1 = Sheets("Sheet1")
Set s2 = Sheets("Sheet2")
Set s3 = Sheets("comparison")
s1.Select
Set rComp = Application.InputBox(Prompt:="Select range", Type:=8)
addy = rComp.Address
ary1 = rComp
ary2 = s2.Range(addy)
ary3 = s3.Range(addy)
K = 1
For I = LBound(ary1, 1) To UBound(ary1, 1)
For J = LBound(ary1, 2) To UBound(ary1, 2)
If ary1(I, J) = ary2(I, J) Then
ary3(I, J) = "TRUE"
Else
ary3(I, J) = "FALSE"
End If
Next J
Next I
s3.Range(addy) = ary3
End Sub
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.