0
美好的一天,多條件匹配/搜索vba
我抨擊我的腦袋試圖找出如何編程多個工作表上的多條件搜索。
我有3個數據行a:日期,行b:字符串,行c:金額。我的目標是在所有三張表格中找到具有b和c列完全匹配的副本。結果匹配應複製到新創建的工作表上。
這是我到目前爲止已經試過:
Dim WS As Worksheet, WS1 As Worksheet, WS2 As Worksheet, WS3 As Worksheet
Dim st_cell As Range, frow1 As Range, frow2 As Range, frow3 As Range, mydata As Range, cell As Range, Descr1 As Range, Descr2 As Range, Descr3 As Range
Dim p As Long
Set WS1 = ThisWorkbook.Sheets(2)
Set WS2 = ThisWorkbook.Sheets(3)
Set WS3 = ThisWorkbook.Sheets(4)
Sheets.Add after:=Sheets(Sheets.Count)
Sheets(ActiveSheet.Name).Name = "Report"
Sheets("Report").Range("A1") = "Description"
Sheets("Report").Range("B1") = "Amount"
erow = Sheets("Report").Cells(1, 1).CurrentRegion.Rows.Count + 1
Set st_cell = WS1.Cells(2, 2)
lastrow = WS1.Cells(WS1.Rows.Count, st_cell.Column).End(xlUp).row
Set frow1 = WS2.Cells(2, 2)
lastrow1 = WS2.Cells(WS2.Rows.Count, frow1.Column).End(xlUp).row
Set frow2 = WS3.Cells(2, 2)
lastrow2 = WS3.Cells(WS3.Rows.Count, frow2.Column).End(xlUp).row
With WS1
For i = 2 To lastrow
Set Descr1 = WS1.Range(Cells(i, 2), Cells(i, 3))
For Each Descr1 In ThisWorkbook.Worksheets
If (Descr1 <> Empty) Then
For p = 2 To lastrow1 And lastrow2
Set Descr2 = WS2.Range(Cells(p, 2), Cells(p, 3))
Set Descr3 = WS3.Range(Cells(p, 2), Cells(p, 3))
Set mydata = WS1.Range(Cells(i, 2), Cells(i, 3)).Find(what:=Descr1, after:=.Cells(i, 2), LookIn:=xlValues, lookat:=xlWhole)
If Not mydata Is Nothing Then
Sheets("Report").Cells(erow, 1) = WS1.Cells(i, "b")
Sheets("Report").Cells(erow, 2) = WS1.Cells(i, "c")
Exit Sub
End If
Next p
End If
Next Descr1
Next i
End With
End Sub
當運行它,我得到一個錯誤:工作表超出範圍。請幫忙。
在此先感謝。
HI Michal,第4張是主頁,我沒有將它包含在上面複製的代碼中,但它在我的文件中。此外,這是一個更大的代碼的一部分,我只是包含了相關的部分或我所假設的。 –