You’ve made a complex spreadsheet to automate a good portion of your business. Great! But you still have the mundane task of sending the same emails over and over again. The good news is that you can send emails directly from a Google Sheet, automating yet another portion of your work. Sending emails is actually quite easy, so I’ll go through it step by step.
A couple reasons you might want to send emails from a good sheet include:
Automated Report Generation - Share reports with the team as they are created.
Reminders - Managing projects in google sheets, send reminders for deadlines and overdue items, send notifications when items are completed.
Invoice Automation - You’ve made the invoice in Google Sheets, skip a step and have it send automatically too! No more sending the wrong invoice to the wrong person.
How to send emails from Google Sheets
In your spreadsheet, go to tools > script editor.
data:image/s3,"s3://crabby-images/d2183/d21836f4569975cb8e2114cd62a8288b9d8b1853" alt="launch the google script ediootr"
Google will now open a new Scripts project for you, with a blank function.
The blank function can be left in or removed.
data:image/s3,"s3://crabby-images/bf6b7/bf6b73fd5de1b7f55b95dab1eb60fe8dca887f2b" alt="Blank Script Project"
Next, we are going to create a send email function.
Now, this function is a bit silly as it only has one line, but it is setting us up for later,
data:image/s3,"s3://crabby-images/8f1cb/8f1cb7989c8bcbf82afd33c95cb986438f16398c" alt="basic function to send email"
Our next step is that we need to check if email quota remains. Google limits gmail users to 100 emails per day, and G Suite users to 1,500 emails per day. We can check this and alert the user when no quota remains.
data:image/s3,"s3://crabby-images/fcea9/fcea923172bebcdfa7e70786015c5b01a1b1c1c0" alt="Send Email with Quota Check"
Now we need to actually get the email addresses, subjects, and messages.
Assuming you already have a sheet that can generate this information, we will start by loading the data from this range.
To actually get the range, we have two options: specify the range in code, or use the active range. The active range is the currently highlighted set of cells in our sheet.
If the range never changes, specifying the range manually will yield better consistency, but using the active range gives a bit more flexibility.
data:image/s3,"s3://crabby-images/4c211/4c211300375b97350367d69c776a6bd446a3785e" alt="Get Email Info from Spreadsheet"
Next we get the data for each email. We are making the assumption here that 3 columns have been selected, and that the order is email, subject, message. With this data, we will use our send function.
data:image/s3,"s3://crabby-images/a24b3/a24b3ea4258256b29d4224745c34e835e1b3f14a" alt="Get email data values and send email"
Now, save the script, select our getEmailInfoAndSendEmail function, and hit run.
data:image/s3,"s3://crabby-images/6b6e0/6b6e07c2ade64b5fcd0abd736b881a98db52da71" alt="Run the script"
Your recipients should soon be greeted with their emails.
data:image/s3,"s3://crabby-images/5d9e5/5d9e501adb01ec679dd8ff82f97077a4d88130a6" alt="Wait for emails to send"
What else can you do with Emails from Google Sheets?
Add a menu to launch our email script
Its a bit annoying to have to open the scripts page to run our script. Adding the following function onOpen will add a menu shortcut under Add-ons when the sheet is loaded.
data:image/s3,"s3://crabby-images/3297f/3297f3356db0b41b55e5a3d2fd53d90fffe2321e" alt=""
File Attachments
You can attach files from the Google Drive to your emails. Just remember to change the MimeType.PDF if you are sending something other than a PDF.
data:image/s3,"s3://crabby-images/25766/257667297afeaa6c7b10b0ad36014cae1b6a8a52" alt="Send an email with an attachment"
Add a CC recipient
data:image/s3,"s3://crabby-images/c0e0b/c0e0b57cb446c8e8d14ac6d27efdf103eb493e08" alt=""
Change the Reply To address
data:image/s3,"s3://crabby-images/16c6c/16c6c4024ecd05d6c27af0ba5af7bc7dd9cb0b6b" alt="Send email with reply to address"
To get a complete list of options for using the MailApp, checkout the google documentation: https://developers.google.com/apps-script/reference/mail
If you have any questions about automation or software development, feel free to reach out to me via email at caden.armstrong@smartbenchsoftwaree.com
Comments