Brevo (Sendinblue) → AcelleMail Migration — Visual Walkthrough

Export contacts from Brevo, upload to AcelleMail in 6 clicks. UI walkthrough on both sides plus optional API-driven migration for large lists.

Before you start

You'll need:

  • A Brevo account with contact-list export permission
  • An AcelleMail installation up and running
  • ~30 minutes for <50k contacts

Export from Brevo

In Brevo's left sidebar, click ContactsLists → choose the list to export. On the list detail page, click Export contacts in the top-right.

Brevo asks for export format — pick CSV. The file is prepared in the background; check Export history for the download link (usually <2 minutes).

The exported CSV includes: email, all custom attributes (FIRSTNAME, LASTNAME, custom fields), list memberships, opt-in date, blacklist status.

For attribute mapping, note Brevo's field names — they map to AcelleMail's custom fields in the next step.

Import into AcelleMail (the same 6 clicks for every source)

Once you have the CSV exported from your previous platform, the import flow in AcelleMail is identical regardless of where the data came from.

1. Open your destination list

In AcelleMail's sidebar, click Audience → choose the list that will receive the migrated subscribers (or create a new one — New list button top-right).

Lists index

You'll see a per-list overview card with subscriber counts:

List overview

2. Click "Import" in the list toolbar

The wizard entrypoint is on the list detail page:

Import entry point

3. Upload your CSV

Drop the CSV file from the previous platform into the upload area:

Upload empty state

AcelleMail parses the file and confirms detection:

Upload success

4. Map the columns

The wizard auto-detects standard columns (email, first_name, last_name) and shows green Mapped to EMAIL chips. Adjust manually for any non-standard column from the source:

Map columns

5. Pick duplicate handling

In the same screen, choose what AcelleMail does when a subscriber already exists in this list:

  • Skip — keep the existing row, don't overwrite
  • Update — overwrite name/tags/custom fields with values from the CSV
  • Unsubscribe — mark existing rows as unsubscribed (rare; used when re-importing an opted-out list)

6. Run the import

Click Start import. The job runs in the background — close the popup, work elsewhere, return to Audience → [list] → Import to see progress:

Import history

You'll see PendingRunningComplete per import job, with rows-imported / rows-skipped / errors counts.

After the import

  • Verify list count matches your expected size (rows that failed validation appear in the Errors column with a downloadable error CSV).
  • Re-tag if needed — for behavioural data that doesn't fit a CSV column (e.g. "opened campaign X"), you may need to re-create the tag via segmentation rules.
  • Pause for warm-up — if the imported list is large (>10k) and your sending IP is new or recently rotated, run a short warm-up campaign to your most-engaged 10% before the full send. See IP warm-up best practices for the schedule.

Rebuilding workflows

Brevo's "automations" map to AcelleMail's Automation workflows. Equivalent triggers:

Brevo trigger AcelleMail trigger
Subscribed to list Subscribed to list
Custom attribute change Field value change
Date attribute matches Date relative
Webhook event Custom event (API)
Email opened/clicked in campaign Link clicked

Re-create each automation via Automations → New automation in AcelleMail — same drag-and-drop builder, same step types.

Merge-tag syntax differences

Brevo uses {{contact.FIRSTNAME}}; AcelleMail uses {{ subscriber.first_name }}. Find/replace patterns:

Brevo AcelleMail
{{contact.FIRSTNAME}} {{ subscriber.first_name }}
{{contact.LASTNAME}} {{ subscriber.last_name }}
{{contact.EMAIL}} {{ subscriber.email }}
{{mirror}} {{ web_view_url }}
{{unsubscribe}} {{ unsubscribe_url }}
Advanced: API-driven migration for large lists

For lists >500k or scripted CI-driven sync, both platforms expose REST APIs.

Export from Brevo via API:

curl -X GET "https://api.brevo.com/v3/contacts?limit=1000&offset=0" \
  -H "api-key: <BREVO_API_KEY>" \
  -o brevo-contacts.json

Brevo's API returns 1000-row pages; paginate via offset.

Import into AcelleMail via REST API:

ACELLE_TOKEN="..."
ACELLE_LIST_UID="..."

jq -c '.contacts[] | {email: .email, first_name: .attributes.FIRSTNAME, last_name: .attributes.LASTNAME}' brevo-contacts.json \
  | while read subscriber; do
      curl -X POST "https://acellemail.com/api/v1/subscribers" \
        -H "Authorization: Bearer $ACELLE_TOKEN" \
        -d "{\"list_uid\":\"$ACELLE_LIST_UID\",\"subscriber\":$subscriber}"
    done

The CSV-through-UI path is faster for one-time migration; API path is for scheduled sync.

Related articles

7 commenti

5 commenti

  1. lucas.bernard.…
    reading this 2 weeks into our mailchimp migration. the 8-week timeline is conservative but accurate — we tried to compress to 4 weeks and got bitten by exactly the dns warmup mistake you describe.
    1. admin
      appreciate it. if anything in this needs updating, ping us — we revisit articles every few months.
  2. joel.anders.se
    Bookmarked. We're evaluating a move next quarter and this is the most operationally-realistic guide I've found
  3. emma.whitaker
    Completed this migration in Q1. The list-cleanup step is even more important than this guide makes it. We had 40k subscribers, exported, found that 6k were already on Mailchimp's suppression list. Importing those would've torched our new sender reputation.
  4. linhpm.devs
    if your mailchimp account has automations triggered by tags, document them carefully before export — the audit log goes away when you cancel the account and you'll need that reference during the rebuild.
    1. admin
      Yep, same pattern works for us. Thanks for sharing tbh
  5. sofia.costa.pt
    Tip for anyone planning this: do a dry-run of the import with a small test list first. We caught a CSV encoding issue (Excel saved BOM-prefixed UTF-8) that wouldve affected all 60k rows.

More in Migration & Comparison