List of names and Dates, send an email automatically if it is todays date.

PaulOPTC

New Member
Joined
Jan 13, 2022
Messages
48
Office Version
  1. 365
Platform
  1. Windows
Hey! I've seen a bunch of similar threads, and I've tried some of their codes and modified them to meet my own needs, but nothing is working as planned.

Here is what I need to do:

I have a list of employees, after 90 days of being employed, they are "no longer on probation". And are offered health insurance, and a company truck etc.

After 60 days of them being employed, I want it to send me an email saying "(F5) is almost eligible for health insurance, please send them an email of our current package."

After 80 days "(F5) needs to send back the paper work by next week, please confirm they have accepted or denied coverage"


This is what it would look like


Hidden Helper columns --------------------------------------------------------------------------------------------------
First Name (A5)Last Name (B5)Start date (C5)Health insurance (D5).....Name (G5)insurance first check (H5)email sent? (I5)second check (J5)second sent? (K5)
=[@[First Name]]&" "&[@[Last Name]]=IF([@[Start Date]]>0,[@[Start Date]]+60,"")=IF([@[Start Date]]>0,[@[Start Date]]+80,"")

It is a table, we usually only have like 20 employees at a time, and while all 20 will be on this list, the only ones we care about will be the new ones. But the table could be sorted at any point.

So I would need the code to go and look at H6 ~ H80 (for future proofing)
If there is a date, check to see if it is on or before today's date
if it is on or before today's date look in column I to see if the email was sent,
if it was already sent, do nothing
if it hasn't been sent, to send the first email, and mark off in the column that the first email was sent.
and then I need it to check j6~j80 for and repeat the same steps.



If anyone is willing to help me complete this task I would really appreciate it!
 

Excel Facts

Format cells as time
Select range and press Ctrl+Shift+2 to format cells as time. (Shift 2 is the @ sign).
Perhaps something like this would work?
VBA Code:
Sub Email_Check_Send()

    Dim OutApp As Object
    Dim OutMail As Object
    Dim lrow As Integer
    Dim i As Long
    Dim Recipients As String
    Dim RecipientsClm As Integer
    
    
    RecipientsClm = 5 '******This represents the column that the email address is in
    
    lrow = Cells(Rows.Count, 7).End(xlUp).Row
    On Error Resume Next
    'Only the visible cells in the selection
    
    For i = 2 To lrow 'Loop through each record
        'First Email:
        If Cells(i, RecipientsClm) <> "" And Cells(i, 8) <> "" Then 'If Email exisits and start date isn't blank then...
            If Cells(i, 8) <= Now And Cells(i, 9) = "" Then 'If First Check date is before or on today, and the email sent is blank then...
                
                'Email Section:
                Recipients = Cells(i, RecipientsClm)
                Set OutApp = CreateObject("Outlook.Application")
                Set OutMail = OutApp.CreateItem(0)
            
                With OutMail
                    .To = Recipients
                    .CC = ""
                    .BCC = ""
                    .Subject = "Subject Goes Here"
                    .HTMLBody = "Email 1 Text goes here"
                    .Send   'or use .Display if you do not want to auto-send
                End With

                Cells(i, 9) = "X" 'Indicates the individal has been emailed
            End If
        
        End If
        
        
        'Second Email:
        If Cells(i, RecipientsClm) <> "" And Cells(i, 10) <> "" Then 'If Email exisits and start date isn't blank then...
            If Cells(i, 10) <= Now And Cells(i, 11) = "" Then 'If First Check date is before or on today, and the email sent is blank then...
                
                'Email Section:
                Recipients = Cells(i, RecipientsClm)
                Set OutApp = CreateObject("Outlook.Application")
                Set OutMail = OutApp.CreateItem(0)
            
                With OutMail
                    .To = Recipients
                    .CC = ""
                    .BCC = ""
                    .Subject = "Subject Goes Here"
                    .HTMLBody = "Email 1 Text goes here"
                    .Send   'or use .Display if you do not want to auto-send
                End With

                Cells(i, 11) = "X" 'Indicates the individal has been emailed
            End If
        
        End If
    Next i

End Sub
 
Upvote 0
Solution
Note, you need to change the first variable "RecipientsClm" to the column number where the individual's email lives. (e.g. If the individual's emails live in column P, then change 5 -> 16)
 
Upvote 0
Note, you need to change the first variable "RecipientsClm" to the column number where the individual's email lives. (e.g. If the individual's emails live in column P, then change 5 -> 16)
Awesome! It worked!

Thank you so much for your help!
 
Upvote 0

Forum statistics

Threads
1,224,828
Messages
6,181,215
Members
453,024
Latest member
Wingit77

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