Mask Time Entry in Excel

< Back to Search results

 Category: [Excel]  Demo Available 

Mask Time Entry in Excel


Excel VBA: Mask Time Entry in Excel. Enter Times in Excel With Masked Format

Unlike Access, Excel does not allow for us to mask time and/or date entries. However, we can use the worksheet change event to achieve masked time entries. For the code to work times should be entered as 4 digits, e.g. 2244, 0130, 1325 will change to 22:44, 01:30 and 13:25 respectively. Note how the time mask is only applicable to the range A1:A100, but can be any range. You can change the display format (.NumberFormat = "[h]:mm") of the code to suit your needs.

To insert the code, right click on the Sheet name tab, select View Code and in here paste the code below;

Private Sub Worksheet_Change(ByVal Target As Range)

Dim vVal

    If Target.Cells.Count > 1 Then Exit Sub

    If Intersect(Target, Range("A1:A100")) Is Nothing Then Exit Sub


     With Target


         vVal = Format(.Value, "0000")

          If IsNumeric(vVal) And Len(vVal) = 4 Then

            Application.EnableEvents = False

            .Value = Left(vVal, 2) & ":" & Right(vVal, 2)

            .NumberFormat = "[h]:mm"

          End If

    End With


     Application.EnableEvents = True

End Sub

See also:

Mask Date Entry in Excel


See also Index to Excel VBA Code and Index to Excel Freebies and Lesson 1 - Excel Fundamentals and Index to how to… providing a range of solutions.


Click here to visit our Free 24/7 Excel/VBA Help Forum where there are thousands of posts you can get information from, or you can join the Forum and post your own questions.


stars (0 Reviews)