Import ActiveCampaign Data to Google Sheets
In this guide, we’ll walk through how to pull data from the ActiveCampaign API directly into Google Sheets, using the API Connector add-on for Sheets. We’ll first get an API key from ActiveCampaign, and then set up a request to pull in email campaign data from ActiveCampaign to your spreadsheet.
- Before You Begin
- Part 1: Get ActiveCampaign API Key
- Part 2: Create your API Request URL
- Part 3: Pull ActiveCampaign API Data into Sheets
- Part 4: Handle Pagination
BEFORE YOU BEGIN
Click here to install the API Connector add-on from the Google Marketplace.
PART 1: GET YOUR ACTIVECAMPAIGN API KEY
- Log in to ActiveCampaign and click “Settings” in the left side navigation menu.
- The Account Settings menu will appear. Click “Developer”.
- You should now see a page containing your API URL and Key. Keep the key handy as you’ll need it in a moment. Congrats! You’re now ready to use the ActiveCampaign API.
PART 2: CREATE YOUR API REQUEST URL
We’ll first set up a pull to view your contact list.
- Base URL: https://YOUR_DOMAIN.api-us1.com/api/3/
- Endpoint: /contacts
Putting it all together, we get the full API Request URL:
PART 3: PULL ACTIVECAMPAIGN API DATA INTO SHEETS
We can now enter all our values into API Connector and import ActiveCampaign data into Google Sheets.
- Open up Google Sheets and click Add-ons > API Connector > Open.
- In the Create Request tab, enter the Request URL we just created
- Under Headers, enter a key-value pair like this:
Replace YOUR_API_KEY with the API key provided above in the first part.
- We don’t need extra authentication so just leave Authentication as None. Create a new tab and click ‘Set current’ to use that tab as your data destination.
- Name your request and click Run. A moment later you’ll see ActiveCampaign data populate the AC_contacts tab in your Google Sheet:
- If your contacts utilize custom fields, these custom field values can be retrieved using the
/fieldValuesendpoint. As the fieldValues endpoint will only produce their ID, you can also use the
/fieldsendpoint to get their name. Once you have all the values in Sheets, you can merge them together as desired using queries and other functions native to Sheets.
- Change the endpoints as described in the documentation to retrieve different data. For example, changing it from
/campaignswill produce a list of all your ActiveCampaign campaigns.
PART 4: HANDLE PAGINATION
- Note Active Campaign’s limits on the number of records returned on a response. By default, only 20 records will be returned unless you use the ‘limit’ and ‘offset’ parameters as described in their documentation.
To get 100 records, you’d use the ‘limit’ parameter and to return more than 100 you’d then make a second request using the ‘offset’ parameter. For example:
- With API Connector you can either run these request URLs manually or loop through them automatically with offset-limit pagination handling (paid feature), like this:
- API URL: enter your request URL as usual, making sure to include limit=100
- Pagination type:
- Offset parameter:
- Limit parameter:
- Limit value:
- Number of pages: enter the number of pages you’d like to fetch