EMAIL REMINDERS FROM EXCEL VBA

shahzeb123

Board Regular
Joined
Jul 29, 2021
Messages
63
Office Version
  1. 2016
Platform
  1. Windows
Hi Guys

Good to be back

I have one sheet which actually a check list for banks KYC/DD documents which is made according to coutnries. Therefore, in one workbook it can have 20 sheet or 19.

What i want is VBA to go through the whole sheet compare the today() formula to column J of every sheet and if any date has less then 7 days difference or already passed then it should pick up the same line column C (which wll be the document name ) and sent an email xxx.com the subject should be the bank name which is written on D6 on everey sheet.

I have very high hopes from u guys, please HELP !!!!

i have extracted following code from internet but it did not serve the purpose;;

Public Sub SendReminderMail()
'Declare the variables
Dim XDueDate As Range
Dim XRcptsEmail As Range
Dim xMailContent As Range
Dim xRngDn As Range
Dim xCrtOut As Object
Dim xValDateRng As String
Dim xValSendRng As String
Dim k As Long
Dim xMailSections As Object
Dim xFinalRw As Long
Dim CrVbLf As String
Dim xMsg As String
Dim xSubEmail As String
On Error Resume Next
'To select the date column insert a input box
Set XDueDate = Application.InputBox("Select the column for Deadline/Due Date date column:", "ExcelDemy", , , , , , 8)
If XDueDate Is Nothing Then Exit Sub
'Insert a input box for selecting the recipients
Set XRcptsEmail = Application.InputBox("Choose the column for the email addresses of the recipients:", "ExcelDemy", , , , , , 8)
If XRcptsEmail Is Nothing Then Exit Sub
'To enter the text mail, insert a input box
Set xMailContent = Application.InputBox("In your email, choose the column with the reminded text:", "ExcelDemy", , , , , , 8)
If xMailContent Is Nothing Then Exit Sub
'Count rows for the due dates
xFinalRw = XDueDate.Rows.Count
Set XDueDate = XDueDate(1)
Set XRcptsEmail = XRcptsEmail(1)
Set xMailContent = xMailContent(1)
'Set command to open MS Outlook Application
Set xCrtOut = CreateObject("Outlook.Application")

'Apply For loop to conduct the operation in each row one by one
For k = 1 To xFinalRw
xValDateRng = ""
xValDateRng = XDueDate.Offset(k - 1).Value
'Apply If condition for the Due Date values
If xValDateRng <> "" Then
'Condition set to send mail if the difference between due dates and current date is greater than 1 and less than 7 days
'Means 1 < X< 7, X = Due Date - Current Date
If CDate(xValDateRng) - Date <= 7 And CDate(xValDateRng) - Date > 0 Then
xValSendRng = XRcptsEmail.Offset(k - 1).Value
'Create the subject, body and text contents with the required variables
xSubEmail = xMailContent.Offset(k - 1).Value & " on " & xValDateRng
CrVbLf = "<br><br>"
xMsg = "<HTML><BODY>"
xMsg = xMsg & "Dear " & xValSendRng & CrVbLf
xMsg = xMsg & "Text : " & xMailContent.Offset(k - 1).Value & CrVbLf
xMsg = xMsg & "</BODY></HTML>"
'Create the email
Set xMailSections = xCrtOut.CreateItem(0)
'Define the position to place the Subject, Body and Recipients Address
With xMailSections
.Subject = xSubEmail
.To = xValSendRng
.HTMLBody = xMsg
.Display

.Send

End With
Set xMailSections = Nothing
End If
End If
Next
Set xCrtOut = Nothing
End Sub
 

Excel Facts

Links? Where??
If Excel says you have links but you can't find them, go to Formulas, Name Manager. Look for old links to dead workbooks & delete.
Untested here :

VBA Code:
Sub CheckDatesAndSendEmails()
    Dim ws As Worksheet
    Dim lastRow As Long, i As Long
    Dim docName As String, bankName As String
    Dim emailBody As String, emailSubject As String
    Dim mailItem As Object
    Dim outlookApp As Object
    Dim emailRecipient As String
    Dim targetDate As Date

    ' Initialize Outlook application
    On Error Resume Next
    Set outlookApp = CreateObject("Outlook.Application")
    If outlookApp Is Nothing Then
        MsgBox "Outlook is not installed or not accessible.", vbExclamation
        Exit Sub
    End If
    On Error GoTo 0

    ' Email recipient
    emailRecipient = "xxx.com"

    ' Loop through each sheet in the workbook
    For Each ws In ThisWorkbook.Worksheets
        ' Get bank name from cell D6
        On Error Resume Next
        bankName = ws.Range("D6").Value
        If bankName = "" Then GoTo NextSheet
        On Error GoTo 0

        ' Find the last row with data in column J
        lastRow = ws.Cells(ws.Rows.Count, "J").End(xlUp).Row

        ' Loop through rows to check dates
        For i = 2 To lastRow ' Assuming data starts at row 2
            On Error Resume Next
            targetDate = ws.Cells(i, "J").Value
            If IsDate(targetDate) Then
                If targetDate - Date <= 7 Then
                    ' Prepare email body with document name from column C
                    docName = ws.Cells(i, "C").Value
                    If docName <> "" Then
                        emailBody = emailBody & "Document: " & docName & " is due or overdue.\n"
                    End If
                End If
            End If
            On Error GoTo 0
        Next i

        ' If emailBody is not empty, send email
        If emailBody <> "" Then
            emailSubject = "KYC/DD Alert for " & bankName
            Set mailItem = outlookApp.CreateItem(0) ' Create a new mail item
            With mailItem
                .To = emailRecipient
                .Subject = emailSubject
                .Body = emailBody
                .Send ' Send the email
            End With
            emailBody = "" ' Reset for the next sheet
        End If

NextSheet:
    Next ws

    MsgBox "Emails sent for sheets with due or overdue documents.", vbInformation

    ' Cleanup
    Set mailItem = Nothing
    Set outlookApp = Nothing
End Sub
 
Upvote 0

Forum statistics

Threads
1,225,689
Messages
6,186,449
Members
453,355
Latest member
Shaz_7

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top