Create emails from a Google spreadsheet

code • January 6, 2018

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.

Screenshot of Google spreadsheet with sample data

Set up the script

Open up the tab of a Google spreadsheet that has your data.

  1. Click Tools > Script editor... from the toolbar.
  2. Replace the code in the Code.gs tab with the following script.
  3. Click the save icon or click File > Save from the toolbar.
  4. 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:

  1. Click the play icon or click Run > Run function > draftMyEmails from the toolbar.
  2. A window should appear. Click “Review Permissions.”
  3. 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.
  4. 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:

Screenshot of emails drafted in Gmail
Keep reading code