Налаштування оновлення цін за розкладом із зовнішніх джерел 1С-Бітрікс

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

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

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

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

  • 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

Налаштування оновлення цін по розписанню з зовнішніх джерел 1С-Бітрікс

Ручне оновлення цін у каталозі з прайс-листів поставщиків — це щоденна рутина менеджера, яка займає від 30 хвилин до кількох годин. При цьому будь-яка затримка означає продаж за застарілою ціною — або у збиток, або з втратою клієнта. Автоматичне оновлення цін по розписанню усуває людський фактор та скорочує затримку до хвилин.

Джерела даних про ціни

Поставщики надають ціни в різних форматах:

  • CSV/Excel — файл на FTP, по посиланню або email. Найрозповсюджований формат.
  • XML (YML, CommerceML) — структурований формат, часто з додатковими даними (остатки, описи).
  • API — REST або SOAP-ендпоінт поставщика. Найнадійніший варіант, але є не у всіх.
  • 1С-вивантаження — CommerceML-файли з 1С:Підприємства через стандартний обмін.

Для кожного формату потрібна своя обработник, але логіка оновлення цін у Бітрікс однакова.

Структура цін у Бітрікс

Ціни зберігаються у таблиці b_catalog_price. Ключові поля:

  • PRODUCT_ID — ID елемента каталогу.
  • CATALOG_GROUP_ID — тип ціни (роздрібна, оптова, закупівельна). Типи цін задаються у b_catalog_group.
  • PRICE — числове значення.
  • CURRENCY — валюта (ISO-код).

Для оновлення ціни через API:

\Bitrix\Catalog\PriceTable::update($priceId, [
    'PRICE' => $newPrice,
    'CURRENCY' => 'RUB',
]);

Або через старий API, якщо потрібно створити ціну при її відсутності:

CPrice::SetBasePrice($productId, $newPrice, 'RUB');

Алгоритм оновлення

Крок 1. Завантаження прайсу. Скрипт забирає файл з FTP (ftp_get()), скачує по URL (file_get_contents()) або запитує API поставщика.

Крок 2. Парсинг. CSV парсується через fgetcsv(), Excel — через PhpSpreadsheet, XML — через SimpleXMLElement. Результат — масив пар «ідентифікатор товара → ціна».

Крок 3. Маппінг. Артикул поставщика сопоставляється з елементом каталогу Бітрікс. Пошук по властивості PROPERTY_SUPPLIER_ARTICLE або XML_ID:

$element = CIBlockElement::GetList(
    [],
    ['IBLOCK_ID' => $catalogIblockId, 'PROPERTY_ARTICLE' => $supplierArticle],
    false,
    ['nTopCount' => 1],
    ['ID']
)->Fetch();

Крок 4. Оновлення. Запис нової ціни у b_catalog_price. При оновленні тисяч товарів використовуйте прямі SQL-запити або батчеве оновлення через D7 — поелементне оновлення через CPrice::SetBasePrice() занадто повільне.

Наценки та формули

Поставщик надає закупівельну ціну. Роздрібна розраховується за формулою:

  • Фіксована наценка: роздрібна = закупівельна × 1.3 (30%).
  • Прогресивна: наценка залежить від діапазону цін (дешеві товари — 50%, дорогі — 15%).
  • Округлення: ceil($price / 10) * 10 - 1 → ціна 1 287 → 1 289.

Формули наценки зберігаються в конфігурації, а не зашиваються в код. Це дозволяє менеджеру змінювати правила через адміністративний інтерфейс.

Діапазон закупки Наценка Приклад
До 500 ₽ 50% 300 → 450 ₽
500–5 000 ₽ 30% 2 000 → 2 600 ₽
Свыше 5 000 ₽ 15% 10 000 → 11 500 ₽

Cron-налаштування

Оновлення цін запускається по cron:

# Завантаження прайсу поставщика А — щодня о 6:00
0 6 * * * /usr/bin/php /home/bitrix/scripts/update_prices.php --source=supplier_a >> /var/log/price_update.log 2>&1

# Завантаження прайсу поставщика Б — щодня о 6:30
30 6 * * * /usr/bin/php /home/bitrix/scripts/update_prices.php --source=supplier_b >> /var/log/price_update.log 2>&1

Розносьте оновлення по часу — паралельний запуск кількох імпортів навантажує базу та може привести до дедлоків.

Контроль змін

Сліпе оновлення цін небезпечно. Помилка у прайсі поставщика (ціна 100 замість 10 000) приведе до збитків. Механізми захисту:

  • Поріг змін — якщо ціна змінилася більше ніж на 30%, не оновлювати автоматично, а позначити для ручної перевірки.
  • Логування — таблиця price_update_log з полями: товар, стара ціна, нова ціна, джерело, дата. Дозволяє відкатити помилкове оновлення.
  • Сповіщення — email або Telegram-сповіщення менеджеру при аномальних змінах.
$changePercent = abs($newPrice - $oldPrice) / $oldPrice * 100;
if ($changePercent > 30) {
    logAnomaly($productId, $oldPrice, $newPrice, $source);
    continue; // Пропускаємо оновлення
}

Сброс кеша після оновлення

Після масового оновлення цін необхідно сбросити кеш каталогу, інакше користувачі побачать старі ціни:

\Bitrix\Iblock\ElementTable::getEntity()->cleanCache();
BXClearCache(true, '/catalog/');

Для сайтів з композитним кешем додатково викличте \Bitrix\Main\Composite\Engine::deleteAllCache() або точковий сброс сторінок змінених товарів.