DATEDIFFERENCE

Returns the number of days, months or years between two dates.
These replace the built-in function DATEDIF that is no longer supported.


Remarks

* For an illustrated example of the built-in DATEDIF Function refer to the page under Advanced Functions.
* For instructions on how to add a function to a workbook refer to the page under Inserting Functions
* The equivalent JavaScript function is DATEDIFFERENCE



DATEDIFFERENCE_D

Returns the number of whole days between "start_date" and "end_date".

Public Function DATEDIFFERENCE_D( _ 
         ByVal dtStart_Date As Date, _
         ByVal dtEnd_Date As Date) As Long
   
   On Error GoTo ErrorHandler
   Application.Volatile

   DATEDIFFERENCE_D = VBA.Int(dtEnd_Date - dtStart_Date)
   Exit Function
   
ErrorHandler:
   DATEDIFFERENCE_D = -1
End Function

DATEDIFFERENCE_M

Returns the number of whole months (or months and days) (or months, weeks and days) between "start_date" and "end_date".

Public Function DATEDIFFERENCE_M( _ 
         ByVal dtStart_Date As Date, _
         ByVal dtEnd_Date As Date) As Long
   
Dim eom_start As Single
Dim eom_end As Single

Dim number1 As Single
Dim number2 As Single
Dim number3 As Single
   
   On Error GoTo ErrorHandler
   Application.Volatile
      
   eom_start = Application.WorksheetFunction.EoMonth(dtStart_Date, 0)
   eom_end = Application.WorksheetFunction.EoMonth(dtEnd_Date, 0)
   
   number1 = (12 * (VBA.Year(dtEnd_Date) - VBA.Year(dtStart_Date))) - 12 + _
      (12 - VBA.Month(dtStart_Date)) + VBA.Month(dtEnd_Date) - 1

   number2 = (eom_start - dtStart_Date + 1) / VBA.Day(eom_start)
   
   number3 = (1 - (eom_end - dtEnd_Date) / VBA.Day(eom_end))
      
   DATEDIFFERENCE_M = VBA.Int(VBA.Round(number1 + number2 + number3, 1))
   
   Exit Function
   
ErrorHandler:
   DATEDIFFERENCE_M = -1
End Function

DATEDIFFERENCE_Y

Returns the number of whole years (or years and days) (or years, months and days) between "start_date" and "end_date".

Public Function DATEDIFFERENCE_Y( _ 
         ByVal dtStart_Date As Date, _
         ByVal dtEnd_Date As Date) As Long
         
Dim minusnumber As Integer

   On Error GoTo ErrorHandler
   Application.Volatile
      
   If (VBA.Month(dtStart_Date) > VBA.Month(dtEnd_Date)) Then
      minusnumber = 1
   Else
      If (VBA.Month(dtEnd_Date) = VBA.Month(dtStart_Date)) Then
         If (VBA.Day(dtEnd_Date) < VBA.Day(dtStart_Date)) Then
            minusnumber = 1
         Else
            minusnumber = 0
         End If
      Else
         minusnumber = 0
      End If
   End If
   
   DATEDIFFERENCE_Y = VBA.Year(dtEnd_Date) - VBA.Year(dtStart_Date) - minusnumber
   
   Exit Function
   
ErrorHandler:
   DATEDIFFERENCE_Y = -1
End Function

DATEDIFFERENCE_MD

Returns the number of days between "start_date" and "end_date" (ignoring months and years).
We have not used the VBA Operator because this value can be different to the Excel MOD function.

Public Function DATEDIFFERENCE_MD( _ 
         ByVal dtStart_Date As Date, _
         ByVal dtEnd_Date As Date) As Long
   
Dim minusnumber As Integer
Dim number1 As Long
Dim number2 As Long

   On Error GoTo ErrorHandler
   Application.Volatile
   
   minusnumber = 0
   If (VBA.Day(EndDate) = VBA.Day(dtStart_Date)) Then
      DATEDIFFERENCE_MD = 0
   Else
      If (VBA.Day(EndDate) > VBA.Day(dtStart_Date)) Then
         DATEDIFFERENCE_MD = VBA.Day(dtEnd_Date) - VBA.Day(dtStart_Date)
      Else
         number1 = VBA.DateSerial(VBA.Year(dtStart_Date), _
                                  VBA.Month(dtStart_Date) + 1, _
                                  VBA.Day(dtEnd_Date))
         DATEDIFFERENCE_MD = number1 - dtStart_Date
      End If
   End If
      
   Exit Function
   
ErrorHandler:
   DATEDIFFERENCE_MD = -1
End Function

DATEDIFFERENCE_YD

Returns the number of days between "start_date" and "end_date" (ignoring years).
This function always takes the year from the "end_date".

Public Function DATEDIFFERENCE_YD( _ 
         ByVal dtStart_Date As Date, _
         ByVal dtEnd_Date As Date) As Long
   
Dim start_day As Long
Dim start_month As Long
Dim start_year As Long
Dim end_day As Long
Dim end_month As Long
Dim end_year As Long
Dim firstdate As Date
Dim modifylast_year As Long
Dim lastdate As Date
   
   On Error GoTo ErrorHandler
   Application.Volatile
   
 start_day = Day(dtStart_Date)
 start_month = Month(dtStart_Date)
 start_year = Year(dtStart_Date)
 end_day = Day(dtEnd_Date)
 end_month = Month(dtEnd_Date)
 end_year = Year(dtEnd_Date)

   If (start_month = end_month) Then
      If (start_day = end_day) Then
         DATEDIFFERENCE_YD = 0
      Else
         If (start_day <= end_day) Then
            lastdate = VBA.DateSerial(end_year, end_month, end_day)
            firstdate = VBA.DateSerial(end_year, start_month, start_day)
            DATEDIFFERENCE_YD = lastdate - firstdate
         Else
            If (start_year < (end_year - 1)) Then
               lastdate = VBA.DateSerial(end_year + 1, end_month, end_day)
               firstdate = VBA.DateSerial(end_year, start_month, start_day)
               DATEDIFFERENCE_YD = lastdate - firstdate
            Else
               lastdate = VBA.DateSerial(end_year, end_month, end_day)
               firstdate = VBA.DateSerial(end_year, start_month, start_day)
               DATEDIFFERENCE_YD = lastdate - firstdate
            End If
         End If
      End If

   Else
      If (start_month < end_month) Then
         lastdate = VBA.DateSerial(end_year, end_month, end_day)
         firstdate = VBA.DateSerial(end_year, start_month, start_day)
         DATEDIFFERENCE_YD = lastdate - firstdate
      Else
         lastdate = VBA.DateSerial(end_year + 1, end_month, end_day)
         firstdate = VBA.DateSerial(end_year, start_month, start_day)
         DATEDIFFERENCE_YD = lastdate - firstdate
      End If
   End If

   Exit Function
   
ErrorHandler:
   DATEDIFFERENCE_YD = -1
End Function

DATEDIFFERENCE_YM

Returns the number of months between "start_date" and "end_date" (ignoring days and years).

Public Function DATEDIFFERENCE_YM( _ 
         ByVal dtStartDate As Date, _
         ByVal dtEndDate As Date) As Long
         
Dim minusnumber As Integer
Dim number1 As Long
Dim number2 As Long

   On Error GoTo ErrorHandler
   Application.Volatile
   
   minusnumber = 0
   If (VBA.Day(EndDate) < VBA.Day(dtStart_Date)) Then
      minusnumber = 1
   End If
   
   number1 = (12 * (VBA.Year(dtEnd_Date) - VBA.Year(dtStart_Date))) + _
      VBA.Month(dtEnd_Date) - VBA.Month(dtStart_Date) - minusnumber
   
   number2 = 12
      
   DATEDIFFERENCE_YM = number1 - (number2 * VBA.Int(number1 / number2))
   
   Exit Function
   
ErrorHandler:
   DATEDIFFERENCE_YM = -1
End Function

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