How to error handle 1004 Error with WorksheetFunction.VLookup?

前端 未结 3 456
不思量自难忘°
不思量自难忘° 2020-11-22 06:24

I have this code:

Dim wsFunc As WorksheetFunction: Set wsFunc = Application.WorksheetFunction
Dim ws As Worksheet: Set ws = Sheets(\"2012\")
Dim rngLook As R         


        
3条回答
  •  一向
    一向 (楼主)
    2020-11-22 06:48

    Instead of WorksheetFunction.Vlookup, you can use Application.Vlookup. If you set a Variant equal to this it returns Error 2042 if no match is found. You can then test the variant - cellNum in this case - with IsError:

    Sub test()
    Dim ws As Worksheet: Set ws = Sheets("2012")
    Dim rngLook As Range: Set rngLook = ws.Range("A:M")
    Dim currName As String
    Dim cellNum As Variant
    
    'within a loop
    currName = "Example"
    cellNum = Application.VLookup(currName, rngLook, 13, False)
    If IsError(cellNum) Then
        MsgBox "no match"
    Else
        MsgBox cellNum
    End If
    End Sub
    

    The Application versions of the VLOOKUP and MATCH functions allow you to test for errors without raising the error. If you use the WorksheetFunction version, you need convoluted error handling that re-routes your code to an error handler, returns to the next statement to evaluate, etc. With the Application functions, you can avoid that mess.

    The above could be further simplified using the IIF function. This method is not always appropriate (e.g., if you have to do more/different procedure based on the If/Then) but in the case of this where you are simply trying to determinie what prompt to display in the MsgBox, it should work:

    cellNum = Application.VLookup(currName, rngLook, 13, False)
    MsgBox IIF(IsError(cellNum),"no match", cellNum)
    

    Consider those methods instead of On Error ... statements. They are both easier to read and maintain -- few things are more confusing than trying to follow a bunch of GoTo and Resume statements.

提交回复
热议问题