Налаштування оновлення цін по розписанню з зовнішніх джерел 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() або точковий сброс сторінок змінених товарів.







