WEEKDAY |
WEEKDAY(date, [firstdayofweek]) |
Returns the number representing the day of the week for a given date (Integer). |
date | The date you want the day for (Variant). |
firstdayofweek | (Optional) A vbDayOfWeek constant that specifies the first day of the week (Integer): 0 = vbUseSystemDayOfWeek 1 = vbSunday (default) (Monday=2, Sunday=1) 2 = vbMonday (Monday=1, Sunday=7) 3 = vbTuesday (Monday=7, Sunday=6) 4 = vbWednesday (Monday=6, Sunday=5) 5 = vbThursday (Monday=5, Sunday=4) 6 = vbFriday (Monday=4, Sunday=3) 7 = vbSaturday (Monday=3, Sunday=2) |
REMARKS |
* If "firstdayofweek" is left blank, then 1 (vbSunday) is used. * If "firstdayofweek" = vbUseSystemDayOfWeek, this takes the setting from the Control Panel, Region. * Sunday is considered the first day of the week in: USA, Canada, South Africa, India, Japan, South Korea. * Monday is considered the first day of the week in: UK, Germany, France, Australia, New Zealand, China. * If the Calendar property setting is Gregorian, the returned integer represents the Gregorian day of the week for the date argument. * If the calendar is Hijri, the returned integer represents the Hijri day of the week for the date argument. * For Hijri dates, the argument number is any numeric expression that can represent a date and/or time from 1/1/100 (Gregorian Aug 2, 718) through 4/3/9666 (Gregorian Dec 31, 9999). * You can use the DATE function to return the current system date. * You can use the NOW function to return the current system date and time. * You can use the WEEKDAYNAME function to return the day of the week as a string. * The equivalent Excel function is Application.WorksheetFunction.WEEKDAY * The equivalent .NET function is [[Microsoft.VisualBasic.DateAndTime.Weekday]] * For the Microsoft documentation refer to learn.microsoft.com |
Debug.Print VBA.Format("06/07/2024", "dddd") 'Saturday
Debug.Print Weekday(#6/7/2024#, VbDayOfWeek.vbMonday) '5
Debug.Print Weekday(#7/7/2024#, VbDayOfWeek.vbMonday) '7
Debug.Print Weekday(#8/7/2024#, VbDayOfWeek.vbMonday) '3
Debug.Print Weekday(#6/7/2024#, VbDayOfWeek.vbSunday) '6
Debug.Print Weekday(#6/7/2024#, VbDayOfWeek.vbMonday) '5 / vbDayOfWeek.vbThursday
Debug.Print Weekday(#6/7/2024#, VbDayOfWeek.vbTuesday) '4 / vbDayOfWeek.vbWednesday
Debug.Print Weekday(#6/7/2024#, VbDayOfWeek.vbUseSystemDayOfWeek) '5 / vbDayOfWeek.vbThursday
Debug.Print Weekday(VBA.Date) '2
Debug.Print Weekday(VBA.Date, VbDayOfWeek.vbMonday) '1
Debug.Print Weekday(VBA.Date, VbDayOfWeek.vbUseSystemDayOfWeek) '1
Debug.Print Weekday(VBA.Now, VbDayOfWeek.vbSunday) '2, run on a Monday
Debug.Print Weekday(VBA.Now, VbDayOfWeek.vbMonday) '1, run on a Monday
© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited Top