Ako poslať Excel kontakty do Brevo pomocou VBA makra (a alternatíva s Office Scripts)
Funkčné VBA makro, ktoré pošle kontakty z Excel hárka do API Brevo jedným klikom. Plus kedy namiesto toho použiť Office Scripts + Power Automate, a kompromisy oproti riešeniu s Google Apps Script.
Máte kontakty v Exceli a chcete ich mať v Brevo. Rýchla a špinavá odpoveď je uložiť súbor ako .csv a importovať ho, čo je v poriadku raz. Pre čokoľvek, čo robíte opakovane (týždenné odovzdanie obchodu, zošit, ktorý váš tím aktualizuje denne, partnerský zoznam, ktorý sa obnovuje), chcete tlačidlo priamo v Exceli, ktoré urobí synchronizáciu.
Táto príručka pokrýva dve cesty, ktoré pre to skutočne dávajú zmysel:
- VBA makro vložené v zošite. Žiadne licencovanie, žiadny cloud, funguje offline, beží v okamihu, keď používateľ klikne na tlačidlo. Správna odpoveď pre približne 80 % prípadov „Excel do Brevo”.
- Office Scripts + Power Automate. TypeScript namiesto VBA, beží v cloude, podporuje plánované triggery. Správna odpoveď, ak zošit žije v OneDrive/SharePoint a chcete bezobslužnú synchronizáciu, ale buďte si vedomí licencovania Power Automate.
Ak hľadáte ekvivalent pre Google Sheets, pozrite si sprievodný článok o Apps Script. A ak chcete len jednorazový CSV import zo skriptu na vašom laptope, príručka CSV importu má verzie v Pythone, Node.js a cURL.
Čo makro robí
Keď používateľ klikne na tlačidlo „Sync to Brevo” na hárku:
- Prečíta každý riadok z aktívneho pracovného hárka (najprv riadok hlavičky, jeden kontakt na riadok).
- Vybuduje JSON pole tvarované pre parameter
jsonBodyBrevo. - Pošle to na
https://api.brevo.com/v3/contacts/imports API kľúčom uloženým v zošite. - Zobrazí okno správy s výsledkom.
To je všetko. Asi 120 riadkov VBA. Nižšie je celý funkčný modul.
Layout hárka, ktorý makro očakáva
| firstName | lastName | company | city | |
|---|---|---|---|---|
| [email protected] | Jane | Doe | Acme | Berlin |
| [email protected] | John | Smith | Globex | Paris |
email je povinný. Každý ďalší stĺpec sa stáva atribútom kontaktu Brevo, namapovaným cez hlavičku stĺpca (na veľké písmená) na názov atribútu. Takže firstName sa stane FIRSTNAME, company sa stane COMPANY. Vlastné atribúty (čokoľvek nad rámec štandardnej sady) musia najprv existovať vo vašom účte Brevo. Definujte ich v Contacts → Settings → Contact attributes.
Krok 1: otvorte VBA editor
V Exceli: stlačte Alt + F11. Otvorí sa VBA editor. V paneli Project vľavo kliknite pravým tlačidlom na váš zošit a vyberte Insert → Module. Objaví sa prázdny Module1.
Krok 2: vložte celé makro
Nahraďte obsah Module1 týmto:
' ===========================================================================' Brevo contact sync for Excel' Reads the active sheet's rows and POSTs them to Brevo's import API.' ===========================================================================Option Explicit
Private Const BREVO_API_BASE As String = "https://api.brevo.com/v3"Private Const BREVO_LIST_ID As Long = 42 ' <- your Brevo list IDPrivate Const BATCH_SIZE As Long = 1000
' --- Public entry points (the ones you assign to ribbon buttons) -----------
Public Sub SyncSheetToBrevo() Dim apiKey As String apiKey = GetApiKey() If apiKey = "" Then MsgBox "No API key configured. Run ConfigureApiKey first.", _ vbExclamation, "Brevo Sync" Exit Sub End If
Dim ws As Worksheet Set ws = ActiveSheet
Dim emailCol As Long emailCol = FindEmailColumn(ws) If emailCol = 0 Then MsgBox "Sheet must have an 'email' column in row 1.", _ vbExclamation, "Brevo Sync" Exit Sub End If
Dim lastRow As Long, lastCol As Long lastRow = ws.Cells(ws.Rows.Count, emailCol).End(xlUp).Row lastCol = ws.Cells(1, ws.Columns.Count).End(xlToLeft).Column If lastRow < 2 Then MsgBox "No contact rows found.", vbInformation, "Brevo Sync" Exit Sub End If
Dim contacts As Collection Set contacts = New Collection
Dim r As Long, c As Long For r = 2 To lastRow Dim email As String email = LCase(Trim(CStr(ws.Cells(r, emailCol).Value))) If email <> "" And InStr(email, "@") > 0 Then Dim json As String json = "{""email"":""" & EscapeJson(email) & """,""attributes"":{"
Dim attrFirst As Boolean attrFirst = True For c = 1 To lastCol If c <> emailCol Then Dim val As String val = CStr(ws.Cells(r, c).Value) If val <> "" Then If Not attrFirst Then json = json & "," Dim attrName As String attrName = UCase(Trim(CStr(ws.Cells(1, c).Value))) json = json & """" & attrName & """:""" & EscapeJson(val) & """" attrFirst = False End If End If Next c
json = json & "}}" contacts.Add json End If Next r
If contacts.Count = 0 Then MsgBox "No valid contact rows found.", vbInformation, "Brevo Sync" Exit Sub End If
Dim totalSent As Long Dim batchNum As Long Dim okCount As Long, failCount As Long Dim batchStart As Long
For batchStart = 1 To contacts.Count Step BATCH_SIZE batchNum = batchNum + 1 Dim batchEnd As Long batchEnd = batchStart + BATCH_SIZE - 1 If batchEnd > contacts.Count Then batchEnd = contacts.Count
Dim payload As String payload = "{""jsonBody"":[" Dim i As Long For i = batchStart To batchEnd If i > batchStart Then payload = payload & "," payload = payload & contacts(i) Next i payload = payload & "],""listIds"":[" & BREVO_LIST_ID & _ "],""updateExistingContacts"":true,""emptyContactsAttributes"":false}"
Dim ok As Boolean ok = PostToBrevo(apiKey, payload) If ok Then okCount = okCount + 1 totalSent = totalSent + (batchEnd - batchStart + 1) Else failCount = failCount + 1 End If Next batchStart
MsgBox "Sent " & totalSent & " contact(s) in " & batchNum & " batch(es)." _ & vbCrLf & "Successful batches: " & okCount _ & vbCrLf & "Failed batches: " & failCount, _ vbInformation, "Brevo Sync"End Sub
Public Sub ConfigureApiKey() Dim key As String key = InputBox("Paste your Brevo API key (xkeysib-...):", "Brevo API Key") If key = "" Then Exit Sub key = Trim(key) If Left(key, 8) <> "xkeysib-" Then MsgBox "That doesn't look like a Brevo API key (should start with xkeysib-).", _ vbExclamation, "Brevo API Key" Exit Sub End If
On Error Resume Next ThisWorkbook.CustomDocumentProperties("BrevoApiKey").Delete On Error GoTo 0
ThisWorkbook.CustomDocumentProperties.Add _ Name:="BrevoApiKey", _ LinkToContent:=False, _ Type:=msoPropertyTypeString, _ Value:=key
ThisWorkbook.Save MsgBox "API key saved inside the workbook.", vbInformation, "Brevo API Key"End Sub
' --- Private helpers --------------------------------------------------------
Private Function GetApiKey() As String On Error Resume Next GetApiKey = ThisWorkbook.CustomDocumentProperties("BrevoApiKey").Value On Error GoTo 0End Function
Private Function FindEmailColumn(ws As Worksheet) As Long Dim lastCol As Long, c As Long lastCol = ws.Cells(1, ws.Columns.Count).End(xlToLeft).Column For c = 1 To lastCol If LCase(Trim(CStr(ws.Cells(1, c).Value))) = "email" Then FindEmailColumn = c Exit Function End If Next c FindEmailColumn = 0End Function
Private Function PostToBrevo(apiKey As String, payload As String) As Boolean Dim http As Object Set http = CreateObject("MSXML2.XMLHTTP") http.Open "POST", BREVO_API_BASE & "/contacts/import", False http.SetRequestHeader "api-key", apiKey http.SetRequestHeader "Content-Type", "application/json" http.SetRequestHeader "Accept", "application/json" http.Send payload PostToBrevo = (http.Status = 202) If Not PostToBrevo Then Debug.Print "Brevo error " & http.Status & ": " & http.responseText End IfEnd Function
Private Function EscapeJson(s As String) As String Dim r As String r = Replace(s, "\", "\\") r = Replace(r, """", "\""") r = Replace(r, vbCrLf, "\n") r = Replace(r, vbLf, "\n") r = Replace(r, vbCr, "\n") r = Replace(r, vbTab, "\t") EscapeJson = rEnd FunctionKrok 3: uložte zošit ako .xlsm
VBA makrá pretrvávajú iba v zošitoch s povolenými makrami. Uložiť ako, vyberte Excel Macro-Enabled Workbook (.xlsm). Bežný formát .xlsx makrá potichu odstráni. Mnoho ľudí takto stráca kód prvýkrát.
Krok 4: nakonfigurujte svoj API kľúč
Spustite ConfigureApiKey raz. Buď:
- Vo VBA editore kliknite kdekoľvek vnútri sub
ConfigureApiKeya stlačteF5, alebo - V Exceli Developer → Macros, vyberte
ConfigureApiKey, Run.
Vložte svoj kľúč xkeysib-.... Makro ho ukladá ako vlastnú vlastnosť dokumentu vo vnútri samotného zošita. Nie je v zdrojovom kóde, nie je v registroch a cestuje so súborom (takže pozor: ak pošlete .xlsm e-mailom niekomu, API kľúč putuje s ním).
Ak chcete radšej kľúč mimo zošita, prepnite úložisko na register Windows:
' Replace the body of ConfigureApiKey with:SaveSetting "Brevo", "Sync", "ApiKey", key
' And GetApiKey with:GetApiKey = GetSetting("Brevo", "Sync", "ApiKey", "")SaveSetting/GetSetting zapisuje pod HKCU\Software\VB and VBA Program Settings\Brevo\Sync, na používateľa, nie na zošit. Použite to, ak má viacero zošitov zdieľať jeden kľúč, alebo ak nechcete kľúč v súbore.
Krok 5: pridajte tlačidlo na hárok
Toto je to, čo z toho robí zážitok jedného kliku pre netechnických používateľov.
Insert → Shapes → Rectangle, pretiahnite jeden na hárok, popíšte ho „Sync to Brevo.” Pravým tlačidlom myši na tvar, Assign Macro, vyberte SyncSheetToBrevo. Hotovo.
Alebo, pre vyleštenejšie rozhranie, pridajte vlastnú kartu pásu cez Office Custom UI Editor. Ale pre väčšinu interných nástrojov tvar ako tlačidlo bohato stačí.
Krok 6: spustite to
Kliknite na tlačidlo. Makro prečíta riadky, zoskupí ich do dávok, pošle každú dávku do Brevo a zobrazí súhrnné okno. Import Brevo je asynchrónny, takže správa o úspechu znamená „Brevo prijalo dávku”. Skutočné vytvorenie kontaktov sa deje na strane servera v nasledujúcich pár sekundách. Dostanete e-mailový súhrn od Brevo, keď to dokončí (pokiaľ ste nenastavili disableNotification: true).
Bežné úskalia
Tlačidlo nič nerobí a niet chyby. Makrá sú zakázané. Pozrite sa na žltý bezpečnostný pruh v hornej časti hárka a kliknite na Enable Content. Ak vaša organizácia blokuje makrá, pozrite si nižšie cestu cez trust center a podpisovanie kódu.
Compile error: User-defined type not defined. Ste na Mac Exceli, ktorý nemá MSXML2.XMLHTTP. Mac VBA nemôže robiť HTTPS požiadavky priamo. Použite namiesto toho cestu Office Scripts nižšie.
400 Bad Request z Brevo bez zjavnej príčiny. Takmer vždy jedna z: (a) vlastný atribút vo vašom hárku ešte v Brevo neexistuje, najprv ho vytvorte; (b) chyba JSON escapovania, úvodzovky alebo spätné lomítka v hodnotách buniek, ktoré sa neescapovali. Funkcia EscapeJson v kóde rieši štandardné prípady. Ak vaše údaje obsahujú podivné znaky, zalogujte payload do okna Immediate (Debug.Print payload) a preskúmajte.
401 Unauthorized. Zlá hlavička. Je to api-key (malé písmená, pomlčka), nie Authorization. Makro používa správny názov, ale ak ste si skopírovali úryvok inde, dvakrát skontrolujte.
Excel zamrzne pri veľkých importoch. Makro beží synchrónne na UI vlákne. Pre 50 000+ riadkov budete sledovať, ako Excel visí 10 až 30 sekúnd, kým buduje JSON a čaká na Brevo. Buď to akceptujte, alebo prepnite MSXML2.XMLHTTP na jeho asynchrónny variant. Ale v takej škále je vám lepšie v Power Automate (ďalšia sekcia).
Keď VBA nestačí: Office Scripts + Power Automate
VBA nezvládne plánovanú cloudovú synchronizáciu. Ak potrebujete:
- Aby sa zošit synchronizoval do Brevo každú hodinu bez toho, aby ho ktokoľvek otvoril
- Zošit v OneDrive/SharePoint, upravovaný z webu
- IT oddelenie, ktoré zakazuje desktopové makrá
…tak chcete Office Scripts (cloudový ekvivalent Apps Script od Microsoftu) plus Power Automate (ich vrstvu plánovania a HTTP).
Rozdelenie: Office Scripts číta hárok a vracia údaje kontaktov. Power Automate berie tie údaje a posiela ich do Brevo pri triggeri.
Office Script (Excel pre web, Automate → New Script):
function main(workbook: ExcelScript.Workbook): {email: string, attributes: Record<string, string>}[] { const sheet = workbook.getActiveWorksheet(); const range = sheet.getUsedRange(); if (!range) return [];
const values = range.getValues() as string[][]; if (values.length < 2) return [];
const headers = values[0].map(h => String(h).trim()); const emailIdx = headers.findIndex(h => h.toLowerCase() === "email"); if (emailIdx === -1) throw new Error("Sheet must have an 'email' column");
const contacts: {email: string, attributes: Record<string, string>}[] = []; for (let r = 1; r < values.length; r++) { const row = values[r]; const email = String(row[emailIdx] ?? "").trim().toLowerCase(); if (!email || !email.includes("@")) continue;
const attributes: Record<string, string> = {}; for (let c = 0; c < headers.length; c++) { if (c === emailIdx) continue; const v = row[c]; if (v === null || v === "") continue; attributes[headers[c].toUpperCase()] = String(v); } contacts.push({ email, attributes }); } return contacts;}Tok Power Automate:
- Trigger: Recurrence (každú 1 hodinu), alebo manuálne tlačidlo, alebo „When a row is modified”, ak chcete synchronizáciu riadenú zmenou.
- Action: Excel Online → Run script. Ukážte naň váš zošit a skript vyššie. Uložte jeho návratovú hodnotu ako
contacts. - Action: HTTP (toto je Premium konektor, pozrite si nižšie poznámku o licencovaní).
- Method:
POST - URI:
https://api.brevo.com/v3/contacts/import - Headers:
api-key: xkeysib-...,Content-Type: application/json - Body:
{"jsonBody": @{outputs('Run_script')?['body/result']},"listIds": [42],"updateExistingContacts": true}
- Method:
- Action: Condition. Ak stavový kód nie je 202, pošlite upozornenie cez Teams alebo e-mail.
Realita licencovania: akcia HTTP je Premium konektor Power Automate. Na plánoch Microsoft 365 Business Basic/Standard dostávate štandardné konektory, ale nie Premium. Najlacnejšia obchádzka je doplnok Power Automate Premium (asi 15 USD/používateľa/mesiac v čase písania), alebo presunúť HTTP do malej Azure Function, ktorú môže zavolať štandardný tok. Ak ste už na E3/E5 s Premium v balíku, máte vystarané.
To je hlavný dôvod, prečo je príbeh Apps Script čistejší: UrlFetchApp v Apps Script je zadarmo a bez obmedzení, zatiaľ čo ekvivalent od Microsoftu kladie sieťové volanie za platenú úroveň konektora.
VBA vs Office Scripts vs Apps Script: kedy si vybrať čo
| Potreba | Najlepšia možnosť |
|---|---|
| Tlačidlo jedného kliku v zošite, ktorý váš tím už denne otvára | VBA makro (táto príručka, horná polovica) |
| Zošit v OneDrive/SharePoint, hodinová automatická synchronizácia | Office Scripts + Power Automate (potrebuje Premium pre HTTP) |
| Iba Mac Excel, nemôže používať VBA | Office Scripts + Power Automate |
| Údaje žijú v Google Sheets, nie v Exceli | Apps Script (zadarmo, plánované triggery vstavané) |
| Jednorazový import, nikdy už nebude potrebný | Save As → CSV a použite skript pre CSV import |
| Hromadný import zo súboru >10 MB | CSV s fileUrl, pozrite si CSV príručku |
Prečo to poráža Zapier a no-code platformy
Pre opakovanú prácu Excel-do-Brevo si nástroje na automatizáciu tretích strán (Zapier, Make, n8n) účtujú za úlohu a kladú tretiu stranu medzi vaše údaje a Brevo. Cesta VBA má nulové priebežné náklady, žiadny tok údajov tretej strany a žije vo vnútri súboru. Keď sa zošit presunie, integrácia sa presunie s ním. Office Scripts + Power Automate je podobné, ale s Microsoftom ako treťou stranou (už vo vašom stacku, ak ste na M365).
Celý zmysel endpointu Brevo POST /v3/contacts/import je v tom, že nepotrebujete lepiacu platformu. Vaše nástroje už vedia, ako robiť HTTP požiadavky.