Previous Wednesday Date using VBA Functions

Previous Wednesday Date

VBA get Previous Wednesday Date with vbSunday, vbMonday, vbWednesday, vbWednesday, vbThursday, vbFriday and vbSaturday in Excel using VBA Functions. We run so many reports manually or by scheduling reports as part of our daily activities. Sometimes we want to run or schedule reports on specific day in a week.

Lets assume you want to run reports on Wednesday. This tutorial I am going to explain how to find last or previous Wednesday Date using VBA Formulas. We run report based on weekday date, If the output word matches with specified weekday then continue run the report, otherwise it ignores.

Previous Wednesday Date

Get Previous Wednesday Date using VBA Functions

Let us see different statements to find Date of Last or previous Wednesday using Excel VBA. Lets assume today is 3rd December 2018(03/12/2018). The below macro example produces same result. i.e 28th November 2018(28/11/2018).

'Previous Wednesday Date using Excel VBA Functions
Sub VBA_Find_previous_Wednesday()

     Dim dPrevious_Wednesday As Date
     
    dPrevious_Wednesday = DateAdd("ww", -1, Now - (Weekday(Now, vbSunday) - 4))
    Debug.Print dPrevious_Wednesday
    'Or
    dPrevious_Wednesday = DateAdd("ww", -1, Now - (Weekday(Now, vbMonday) - 3))
    Debug.Print dPrevious_Wednesday
    'Or
    dPrevious_Wednesday = DateAdd("ww", -1, Now - (Weekday(Now, vbTuesday) - 2))
    Debug.Print dPrevious_Wednesday
    'Or
    dPrevious_Wednesday = DateAdd("ww", -1, Now - (Weekday(Now, vbWednesday) - 8))
    Debug.Print dPrevious_Wednesday
    'Or
    dPrevious_Wednesday = DateAdd("ww", -1, Now - (Weekday(Now, vbThursday) - 7))
    Debug.Print dPrevious_Wednesday
    'Or
    dPrevious_Wednesday = DateAdd("ww", -1, Now - (Weekday(Now, vbFriday) - 6))
    Debug.Print dPrevious_Wednesday
    'Or
    dPrevious_Wednesday = DateAdd("ww", -1, Now - (Weekday(Now, vbSaturday) - 5))
    Debug.Print dPrevious_Wednesday
    
    MsgBox "If today's date is 12/03/2018 " & vbCrLf & " then previous Wednesday's date is " _
    & Format(dPrevious_Wednesday, "DD MMMM YYYY"), vbInformation, "Previous Wednesday Date"

End Sub

In the above macro we have used different vba functions like DateAdd, Now, Weekday and Format in multiple statements. You can view immediate window, it displays same output.

Note: Use Shortcut ‘Ctrl + G’ for an Immediate window.

Output Screenshot: Please find the output screenshot of above specified macros.

Previous Wednesday Date

Instructions to Run VBA Macro Code or Procedure:

You can refer the following link for the step by step instructions.

Instructions to run VBA Macro Code

Other Useful Resources:

Click on the following links of the useful resources. These helps to learn and gain more knowledge.

VBA Tutorial VBA Functions List VBA Arrays VBA Text Files VBA Tables

VBA Editor Keyboard Shortcut Keys List VBA Interview Questions & Answers Blog

Leave a Comment