Create emails from a Google spreadsheet
Try the updated version of this post where I’ll teach you how to draft your email in Google docs
For this past Ela Conf, we had a record number of proposals submitted, which also (unfortunately) meant a record number of rejection emails we need to send. In the past, we sent these individually, but the sheer volume was going to take hours. We didn’t want to send a mass email because it was important to us to address the proposal submitter by their name and reference their submitted talk title(s).
I found a tutorial that can send emails from a Google spreadsheet and it worked well for us.
I repurposed this script once again at Mapbox as part of our Gender Minority Employee Resource Group’s mentorship program. We matched 64 pairs and we used this script to send an email to introduce the mentor and mentee. This time I updated the script to draft emails so that we could check each email before we sent it out.
I love this script because it feels like you’re creating Mad Libs.
Here’s how you can use it.
Set up your spreadsheet
At the least, you’ll need a row to hold the email addresses. From there, you’ll want to store data in separate rows, for example, a row for the person’s name and other specific information that you’d like to pop into a template. This script also assumes that your first row of data has titles for each column.
Add one last column to your spreadsheet called “Email status” or similar. You’ll use this column in the script to state if an email has already been drafted or sent to keep the script from creating duplicates.
For this example, I’ve created a fake business that matches you with a vegetable. New year, new me.
Set up the script
Open up the tab of a Google spreadsheet that has your data.
- Click
Tools > Script editor...
from the toolbar. - Replace the code in the
Code.gs
tab with the following script. - Click the save icon or click
File > Save
from the toolbar. - Enter a project name, such as “Draft emails”.
Customize the script
Make the script your own by specifying which columns have which data, assigning variables, and using those variables to weave together your message.
Check out the
createDraft
documentation
to learn about more options. For example, you can cc or bcc others on the emails
or add a reply-to address.
I set up the current script to create drafts. If you’d prefer the script to send
emails instead, swap out the GmailApp.createDraft()
function with:
MailApp.sendEmail(
"hello@email.com", // recipient
"To my subscribers", // subject
"Dear subscriber,\nI love you.\nYours,\nKaty", // body
);
Check out the
sendEmail
documentation
to learn about more options you can use to send emails with this function.
Authenticate the script
The first time you run the script you’ll need to grant permission for it to read the spreadsheet and then draft or send emails from your Gmail account:
- Click the play icon or click
Run > Run function > draftMyEmails
from the toolbar. - A window should appear. Click “Review Permissions.”
- Select the account you want to authenticate.
- You may get a warning since this isn’t an official script.
- Review the code to get an idea of how it works and how it will interact with your account.
- Once you feel comfortable, from the warning screen, click “Advanced” then “Go to Draft emails (unsafe)” (or whatever you named your script). This will get you through to the next screen.
- Click “Allow” to grant the script access to the stated parts of your account.
Run the script
After you authenticate, the script will run and you should find as many emails in your Gmail draft folder: