Send WhatsApp Bulk Messages from Google Sheets
WhatsApp Bulk Message Broadcast via Google Sheets (n8n Workflow)
Use Case
This workflow enables automated bulk WhatsApp message broadcasting using the WhatsApp Business Cloud API. It pulls recipient and message data from a Google Sheet, sends templated messages (optionally with image headers), and updates the sheet with the message status. It is ideal for marketing teams, support agents, and businesses handling high-volume outreach.
Who Is This For?
Businesses conducting WhatsApp marketing or outreach campaigns
Customer support or notification teams
Administrators seeking an automated, no-code message distribution system using Google Sheets
What This Workflow Does
Triggers automatically every minute to scan for pending messages
Fetches unsent entries from a Google Sheet
Limits the number of messages processed per execution to comply with API usage guidelines
Sanitizes WhatsApp numbers for proper formatting
Sends messages using a pre-approved WhatsApp template (text and optional image)
Marks the row as "Sent" in the sheet upon successful delivery
Workflow Breakdown (Node by Node)
-
Trigger Every 5 Minutes
Initiates the workflow every minute using a scheduled trigger to continuously monitor pending rows. -
Fetch All Pending Queries for Messaging
Reads rows from a Google Sheet where the Status column is empty, indicating they havenβt been processed yet. -
Limit
Restricts processing to 2 rows per execution to manage API throughput. -
Loop Over Items
Uses SplitInBatches to iterate through each row individually. -
Clean WhatsApp Number
A code node that strips non-numeric characters from the WhatsApp No field, ensuring the format is valid for the API. -
Send Message to 300 Phone No
Sends a WhatsApp message using the WhatsApp Cloud API and a pre-approved template.
Template includes: An image from the Image URL column (as header, optional)
Dynamic variables for the recipient's Name and Message fields
Template variables must be pre-defined and approved in the Meta Developer Portal, such as {{1}}, {{2}}.
- Change State of Rows in Sent1
Updates the Status column to Sent for each successfully processed row using the row number as a reference.
Google Sheet Format
Structure your Google Sheet as shown below:
| WhatsApp No | Name | Message | Image URL | Status | |--------------|------------|---------------------------|---------------------|--------| | +8801XXXXXXX | John Doe | Hello, your order shipped | https://.../img.jpg | |
Leave the Status column empty for rows that need to be processed.
Requirements
WhatsApp Business Cloud API access via Meta for Developers A properly structured Google Sheet as described above Active OAuth2 credentials configured in n8n for: googleSheetsOAuth2Api whatsAppApi
Customization Options
Update the Limit node to control how many rows are processed in each run
Adjust the trigger schedule (e.g., change to every 5 minutes)
Replace the message template ID with your own custom-approved one from Meta
Add error-handling logic (e.g., IF or Try/Catch nodes) to log failures or set Status = Failed
Sample Sheet Template
View Sample Google Sheet
Workflow Highlights
Automated execution every 1 minute
Reads and processes only pending records
Verifies WhatsApp numbers and delivers templated messages
Updates Google Sheet after each attempt
Support & Community
Need help setting up or customizing the workflow?
WhatsApp: Contact Support
Discord: Join SpaGreen Server
Facebook Group: SpaGreen Community
Website: Visit SpaGreen Creative
Related Templates
CrunchBase Competitor Intelligence Tracker
Automated system for monitoring and analyzing competitor activities, funding rounds, and market movements using CrunchB...
Summarize SERPBear data with AI (via Openrouter) and save it to Baserow
Who's this for? If you own a website and need to analyze your keyword rankings If you need to create a keyword report on...
Lookup IP Geolocation Details with IP-API.com via Webhook
This n8n template enables you to instantly retrieve detailed geolocation information for any given IP address by simply ...
π Please log in to import templates to n8n and favorite templates
Workflow Visualization
Loading...
Preparing workflow renderer
Comments (0)
Login to post comments