Інтеграція Бітрікс24 з Power BI

Наша компанія займається розробкою, підтримкою та обслуговуванням рішень на Бітрікс та Бітрікс24 будь-якої складності. Від простих односторінкових сайтів до складних інтернет-магазинів, CRM систем з інтеграцією 1С та телефонії. Досвід розробників підтверджено сертифікатами від вендора.
Пропоновані послуги
Показано 1 з 1 послугУсі 1626 послуг
Інтеграція Бітрікс24 з Power BI
Середня
~1-2 тижні
Часті питання

Наші компетенції:

Етапи розробки

Останні роботи

  • image_website-b2b-advance_0.png
    Розробка сайту компанії B2B ADVANCE
    1262
  • image_bitrix-bitrix-24-1c_fixper_448_0.png
    Розробка веб-сайту для компанії ФІКСПЕР
    851
  • image_bitrix-bitrix-24-1c_development_of_an_online_appointment_booking_widget_for_a_medical_center_594_0.webp
    Розробка на базі Бітрікс, Бітрікс24, 1С для компанії Development of an Online
    585
  • image_bitrix-bitrix-24-1c_mirsanbel_458_0.webp
    Розробка на базі 1С Підприємство для компанії МИРСАНБЕЛ
    751
  • image_crm_dolbimby_434_0.webp
    Розробка сайту на CRM Бітрікс24 для компанії DOLBIMBY
    657
  • image_crm_technotorgcomplex_453_0.webp
    Розробка на базі Бітрікс24 для компанії ТЕХНОТОРГКОМПЛЕКС
    989

Інтеграція Бітрікс24 з Power BI

Відділ аналітики будує звіти вручну в Excel, завантажуючи дані з Бітрікс24 раз на тиждень. Дані застарівають на момент презентації. Power BI з прямим підключенням до REST API Бітрікс24 оновлює дашборди автоматично — раз на годину або за розкладом.

Два підходи до підключення

Підхід 1. Power BI Dataflow + REST API — налаштовується в Power BI Service без програмування. Використовуємо конектор «Web» з автентифікацією через вебхук Бітрікс24. Підходить для невеликих обсягів (до 50 000 записів).

Підхід 2. ETL-процес → проміжна БД → Power BI — Python/Node.js скрипт вивантажує дані з Бітрікс24 API в PostgreSQL/MySQL, Power BI підключається до SQL-бази. Правильний підхід для production: надійніший, швидший, не залежить від лімітів REST API в момент оновлення звіту.

Архітектура ETL-процесу

Bitrix24 REST API → Python ETL → PostgreSQL (аналітична схема) → Power BI

ETL-скрипт запускається за розкладом (щогодини через cron). Схема БД — денормалізовані таблиці під аналітичні запити:

-- Факт-таблиця угод
CREATE TABLE b24_deals (
    id            BIGINT PRIMARY KEY,
    title         TEXT,
    stage_id      VARCHAR(50),
    amount        NUMERIC(15,2),
    currency      VARCHAR(3),
    assigned_id   INT,
    contact_id    INT,
    company_id    INT,
    created_date  TIMESTAMP,
    closed_date   TIMESTAMP,
    pipeline_id   INT
);

-- Виміри
CREATE TABLE b24_users (
    id INT PRIMARY KEY, full_name TEXT, department TEXT, email TEXT
);
CREATE TABLE b24_stages (
    id VARCHAR(50) PRIMARY KEY, name TEXT, pipeline_id INT, sort INT, is_final BOOL
);

Вивантаження даних через REST API

Бітрікс24 REST API повертає дані посторінково (по 50 записів). Потрібен ітеративний збір:

import requests
import psycopg2

WEBHOOK = "https://your-domain.bitrix24.ru/rest/1/token/"
PG_CONN = "postgresql://user:pass@localhost/analytics"

def fetch_all(method, params=None):
    """Посторінкове вивантаження з API Бітрікс24"""
    items, start = [], 0
    while True:
        r = requests.post(WEBHOOK + method, json={
            **(params or {}), "start": start
        }).json()
        items.extend(r.get("result", []))
        if r.get("next") is None:
            break
        start = r["next"]
    return items

def sync_deals():
    deals = fetch_all("crm.deal.list", {
        "select": ["ID","TITLE","STAGE_ID","OPPORTUNITY","CURRENCY_ID",
                   "ASSIGNED_BY_ID","CONTACT_ID","COMPANY_ID",
                   "DATE_CREATE","CLOSEDATE","CATEGORY_ID"],
        "filter": {">=DATE_MODIFY": last_sync_timestamp()},
    })

    conn = psycopg2.connect(PG_CONN)
    cur = conn.cursor()
    for d in deals:
        cur.execute("""
            INSERT INTO b24_deals VALUES (%s,%s,%s,%s,%s,%s,%s,%s,%s,%s,%s)
            ON CONFLICT (id) DO UPDATE SET
                stage_id=EXCLUDED.stage_id, amount=EXCLUDED.amount,
                closed_date=EXCLUDED.closed_date
        """, (d["ID"], d["TITLE"], d["STAGE_ID"], ...))
    conn.commit()

Ключові метрики для дашборда

Power BI будує дашборд поверх аналітичних таблиць. Типові візуалізації:

Метрика Джерело
Воронка угод за стадіями b24_deals GROUP BY stage_id
Виручка по менеджерах b24_deals JOIN b24_users
Конверсія лід → угода → оплата b24_leads JOIN b24_deals
Середній час у стадії Розрахунок за timestamp переходів
Навантаження по менеджерах (активні угоди) Фільтр is_final = false

Оновлення даних у Power BI Service

У Power BI Service налаштовуємо розклад оновлення датасету: підключення до PostgreSQL через On-premises data gateway (якщо БД локальна) або до хмарного PostgreSQL напряму. Частота оновлення — від 1 разу на добу (безкоштовний план) до 8 разів на добу (Premium Per User).

Для оперативного моніторингу продажів — налаштовуємо DirectQuery (реальний час) замість Import Mode. Мінус: запити до БД при кожному відкритті звіту, навантаження на базу.

Інкрементальне завантаження

При великих обсягах (100 000+ угод за історію) повне перезавантаження щогодини — марнотратство. У Power BI Premium налаштовуємо Incremental Refresh: система сама визначає діапазон нових даних за полем дати та довантажує тільки зміни.

Завдання Трудовитрати
ETL-скрипт (Python + psycopg2) 8–12 год
Схема аналітичної БД 4–6 год
Дашборд у Power BI (5–7 звітів) 8–16 год
Налаштування розкладу та моніторингу 3–4 год