Err Object

 

If you are not familiar with Error Handling yet, we highly recommend you to read this example first. When an error in Excel VBA occurs, the properties of the Err object are filled with information.

Situation:

The program below calculates the square root of numbers.

Err Object in Excel VBA

1. Place a command button on your worksheet and add the following code lines:

Dim rng As Range, cell As Range

Set rng = Selection

For Each cell In rng

On Error GoTo InvalidValue:

cell.Value = Sqr(cell.Value)

Next cell

Exit Sub

InvalidValue:

MsgBox Err.Number & ” ” & Err.Description & ” at cell ” & cell.Address

Resume Next

Result when you select Range(“B2:B6”) and click the command button on the sheet:

Err Object Result

Err Object Result

Explanation: when an error occurs, the number property of the Err object is filled with an unique error number of the current error and the Description property is filled with the error description of the current error.

2. These descriptions may not be very helpful to the users of your program. You can make the error messages more user friendly by modifying the last part of the macro as follows:

InvalidValue:

Select Case Err.Number

Case Is = 5

MsgBox “Can’t calculate square root of negative number at cell ” & cell.Address

Case Is = 13

MsgBox “Can’t calculate square root of text at cell ” & cell.Address

End Select

Resume Next

Tip: go through our Select Case program to learn more about the Select Case structure.

Result:

Friendly Message

Friendly Message