VBA Code

To convert a date string to a date value ActiveCell.formulaR1C1 = Activecell.Value.
Using the .Find method to search for dates is not that straight forward
The date you are searching for must be in the default format e.g. 01/07/1996

Set finddate = range("A1:A200").Find (what:="01/07/1998") 

alternatively

Set finddate = range("A1:A200").Find (what:=DateValue("01 07 1998"), lookin:=xlFormulas) 

Custom VBA Functions

Function to returns the number of days, months or years between 2 dates

=DateDifference("date1","date2","units") 
=TimeDifference("time1","time2","units") - mins, secs or hours

or have multiples of both (i.e. 1 day 13 hours)




Functions that calculates the first day of the current month

=TEXT(MONTH(NOW),"DDDD") 
=DATE(YEAR(NOW()),MONTH(NOW()),1)
=eomonth(today(),-1)+1
=TEXT(TODAY()-DAY(TODAY())+1,"ddd, mmm dd, yyyy")
=TEXT(WEEKDAY(DATE(YEAR(NOW()),MONTH(NOW()),1)),"dddd")




This uses the format "Long Date" and "Medium Time" - this makes sure that it works regardless of international settings.
You could use a different format

TheDate = Format(Date, "dd/mm/yyyy") 


Sub DateAndTime() 
' Displays the current date and time

    TheDate = Format(Date, "Long Date")
    TheTime = Format(Time, "Medium Time")

' Determine greeting based on time
    Select Case Time
        Case Is < 0.5: Greeting = "Good Morning, "
        Case Is >= 0.7083: Greeting = "Good Evening, "
        Case Else: Greeting = "Good Afternoon, "
    End Select

' Append user's first name to greeting
    FullName = Application.UserName
    SpaceInName = InStr(1, FullName, " ", 1)
  
' Handle situation when name has no space
    If SpaceInName = 0 Then SpaceInName = Len(FullName)
    FirstName = Left(FullName, SpaceInName)
    Greeting = Greeting & FirstName

' Show the message
    MsgBox TheDate & vbCrLf & TheTime, vbOKOnly, Greeting
End Sub




© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrev