Bird
Raised Fist0
Google Sheetsspreadsheet~10 mins

Sending emails from Sheets in Google Sheets - Cell-by-Cell Formula Trace

Choose your learning style10 modes available

Start learning this pattern below

Jump into concepts and practice - no test required

or
Recommended
Test this pattern10 questions across easy, medium, and hard to know if this pattern is strong
Sample Data

This sheet contains names, their email addresses, and personalized messages to send.

CellValue
A1Name
B1Email
C1Message
A2Alice
B2alice@example.com
C2Hello Alice, your order is ready.
A3Bob
B3bob@example.com
C3Hi Bob, your appointment is confirmed.
Formula Trace
sendEmail(B2, "Order Update", C2)
Step 1: B2
Step 2: "Order Update"
Step 3: C2
Step 4: sendEmail("alice@example.com", "Order Update", "Hello Alice, your order is ready.")
Cell Reference Map
    A          B                   C
1 | Name     | Email             | Message
2 | Alice    | alice@example.com | Hello Alice, your order is ready.
3 | Bob      | bob@example.com   | Hi Bob, your appointment is confirmed.
The formula uses the email address from column B and the message from column C of the same row.
Result
    A          B                   C                   D
1 | Name     | Email             | Message             | Status
2 | Alice    | alice@example.com | Hello Alice, your order is ready. | Email sent
3 | Bob      | bob@example.com   | Hi Bob, your appointment is confirmed. | Email sent
After running the script, a status column can show 'Email sent' to confirm the email was sent for each row.
Sheet Trace Quiz - 3 Questions
Test your understanding
What does the formula sendEmail(B2, "Subject: Order Update", C2) use from the sheet?
AEmail from B2 and name from A2
BName from A2 and message from C2
CEmail from B2 and message from C2
DOnly the message from C2
Key Result
sendEmail(email_address, subject_text, message_text) sends an email using values from specified cells.

Practice

(1/5)
1. What is the main purpose of using Google Apps Script to send emails from Google Sheets?
easy
A. To protect the sheet with a password
B. To send emails automatically using data from the sheet
C. To create charts and graphs in the sheet
D. To sort data alphabetically

Solution

  1. Step 1: Understand the role of Google Apps Script

    Google Apps Script allows automation in Google Sheets, including sending emails.
  2. Step 2: Identify the purpose related to emails

    The script reads data from the sheet and sends emails automatically, saving time.
  3. Final Answer:

    To send emails automatically using data from the sheet -> Option B
  4. Quick Check:

    Sending emails = To send emails automatically using data from the sheet [OK]
Hint: Remember: Apps Script automates tasks like emailing [OK]
Common Mistakes:
  • Confusing email sending with data sorting
  • Thinking Apps Script only creates charts
  • Assuming it protects sheets with passwords
2. Which of the following is the correct way to send an email using Google Apps Script in Google Sheets?
easy
A. MailApp.sendEmail(recipient, subject, body);
B. EmailApp.sendMail(recipient, subject, body);
C. Mail.sendEmail(recipient, subject, body);
D. SendMailApp.email(recipient, subject, body);

Solution

  1. Step 1: Recall the correct Google Apps Script email function

    The correct service is MailApp with the method sendEmail.
  2. Step 2: Verify the syntax

    The syntax is MailApp.sendEmail(recipient, subject, body); which matches MailApp.sendEmail(recipient, subject, body);.
  3. Final Answer:

    MailApp.sendEmail(recipient, subject, body); -> Option A
  4. Quick Check:

    Correct function = MailApp.sendEmail(recipient, subject, body); [OK]
Hint: Use MailApp.sendEmail() to send emails [OK]
Common Mistakes:
  • Using wrong service names like EmailApp or SendMailApp
  • Mixing method names like sendMail instead of sendEmail
  • Incorrect order or spelling of parameters
3. Given this script snippet in Google Sheets:
function sendEmails() {
  var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet();
  var email = sheet.getRange('A2').getValue();
  var message = sheet.getRange('B2').getValue();
  MailApp.sendEmail(email, 'Hello', message);
}

What happens when you run sendEmails()?
medium
A. Nothing happens because sendEmail is not a valid method
B. An error occurs because getRange needs row and column numbers
C. The script sends emails to all rows in the sheet
D. An email is sent to the address in cell A2 with the message from B2

Solution

  1. Step 1: Analyze the script's actions

    The script gets the email from cell A2 and message from B2, then sends an email.
  2. Step 2: Confirm the method usage

    getRange('A2') and getRange('B2') are valid, and MailApp.sendEmail is correct.
  3. Final Answer:

    An email is sent to the address in cell A2 with the message from B2 -> Option D
  4. Quick Check:

    Email sent to A2 with B2 message = An email is sent to the address in cell A2 with the message from B2 [OK]
Hint: Check cell references and MailApp method correctness [OK]
Common Mistakes:
  • Thinking getRange('A2') is invalid syntax
  • Assuming the script sends emails to all rows automatically
  • Believing sendEmail is not a valid method
4. You wrote this script to send emails from your sheet:
function sendEmails() {
  var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet();
  var email = sheet.getRange('A2').getValue();
  var message = sheet.getRange('B2').getValue();
  MailApp.sendEmail(email, 'Subject', message)
}

But it does not send any emails. What is the likely problem?
medium
A. You forgot to authorize the script to send emails
B. Missing semicolon after sendEmail line causes script failure
C. getRange('A2') is incorrect syntax
D. MailApp.sendEmail requires four parameters

Solution

  1. Step 1: Check syntax and parameters

    The script syntax is mostly correct; missing semicolon is not fatal in Apps Script.
  2. Step 2: Consider authorization requirements

    Google Apps Script requires user authorization to send emails; without it, emails won't send.
  3. Final Answer:

    You forgot to authorize the script to send emails -> Option A
  4. Quick Check:

    Authorization needed for sending emails = You forgot to authorize the script to send emails [OK]
Hint: Always authorize scripts before sending emails [OK]
Common Mistakes:
  • Assuming missing semicolon stops script
  • Thinking getRange('A2') is invalid
  • Believing sendEmail needs four parameters
5. You want to send personalized emails to multiple recipients listed in column A, with messages in column B, starting from row 2. Which script correctly sends emails to all rows with data?
hard
A. function sendAllEmails() { var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet(); var lastRow = sheet.getLastRow(); for (var i = 2; i <= lastRow; i++) { var email = sheet.getRange('A' + i).getValue(); var message = sheet.getRange('B' + i).getValue(); MailApp.sendEmail(email, message, 'Hello'); } }
B. function sendAllEmails() { var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet(); var lastRow = sheet.getLastRow(); for (var i = 1; i < lastRow; i++) { var email = sheet.getRange(i, 1).getValue(); var message = sheet.getRange(i, 2).getValue(); MailApp.sendEmail(email, 'Hello', message); } }
C. function sendAllEmails() { var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet(); var lastRow = sheet.getLastRow(); for (var i = 2; i <= lastRow; i++) { var email = sheet.getRange(i, 1).getValue(); var message = sheet.getRange(i, 2).getValue(); MailApp.sendEmail(email, 'Hello', message); } }
D. function sendAllEmails() { var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet(); var lastRow = sheet.getLastRow(); for (var i = 2; i <= lastRow; i++) { var email = sheet.getRange(i, 1).getValue(); var message = sheet.getRange(i, 2).getValue(); MailApp.sendEmail('Hello', email, message); } }

Solution

  1. Step 1: Check loop range and indexing

    The loop must start at row 2 to skip headers and go to lastRow inclusive.
  2. Step 2: Verify getRange usage and sendEmail parameters

    Using getRange(row, column) is correct. sendEmail parameters are (email, subject, message).
  3. Final Answer:

    Loops from row 2 to lastRow and sends emails with correct parameters -> Option C
  4. Quick Check:

    Loop from 2 to lastRow, sendEmail(email, subject, message) = function sendAllEmails() { var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet(); var lastRow = sheet.getLastRow(); for (var i = 2; i <= lastRow; i++) { var email = sheet.getRange(i, 1).getValue(); var message = sheet.getRange(i, 2).getValue(); MailApp.sendEmail(email, 'Hello', message); } } [OK]
Hint: Loop from row 2; use sendEmail(email, subject, message) [OK]
Common Mistakes:
  • Starting loop at row 1 including headers
  • Swapping subject and message parameters
  • Using incorrect getRange syntax