Налаштування імпорту/експорту товарів PrestaShop

Наша компанія займається розробкою, підтримкою та обслуговуванням сайтів будь-якої складності. Від простих односторінкових сайтів до масштабних кластерних систем, побудованих на мікро сервісах. Досвід розробників підтверджено сертифікатами від вендорів.

Розробка та обслуговування будь-яких видів сайтів:

Інформаційні сайти або веб-програми
Сайти візитки, landing page, корпоративні сайти, онлайн каталоги, квіз, промо-сайти, блоги, ресурси новин, інформаційні портали, форуми, агрегатори
Сайти або веб-програми електронної комерції
Інтернет-магазини, B2B-портали, маркетплейси, онлайн-обмінники, кешбек-сайти, біржі, дропшиппінг-платформи, парсери товарів
Веб-програми для управління бізнес-процесами
CRM-системи, ERP-системи, корпоративні портали, системи управління виробництвом, парсери інформації
Сайти або веб-програми електронних послуг
Дошки оголошень, онлайн-школи, онлайн-кінотеатри, конструктори сайтів, портали надання електронних послуг, відеохостинги, тематичні портали

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

Пропоновані послуги
Показано 1 з 1 послугУсі 2065 послуг
Налаштування імпорту/експорту товарів PrestaShop
Середня
~2-3 робочих дні
Часті питання

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

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

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

  • image_website-b2b-advance_0.png
    Розробка сайту компанії B2B ADVANCE
    1262
  • image_web-applications_feedme_466_0.webp
    Розробка веб-додатків для компанії FEEDME
    1171
  • image_websites_belfingroup_462_0.webp
    Розробка веб-сайту для компанії БЕЛФІНГРУП
    874
  • image_ecommerce_furnoro_435_0.webp
    Розробка інтернет магазину для компанії FURNORO
    1094
  • image_crm_enviok_479_0.webp
    Розробка веб-додатків для компанії Enviok
    831
  • image_bitrix-bitrix-24-1c_fixper_448_0.png
    Розробка веб-сайту для компанії ФІКСПЕР
    851

Настройка імпорту/експорту товарів PrestaShop

PrestaShop має вбудований імпортер в розділі Advanced Parameters → Import. Для production-задач з обсягом від 5 000 товарів вбудований інструмент потребує тонкого налаштування або замісту на користувацький розв'язок з пакетною обробкою та управлінням пам'яттю.

Структура CSV для імпорту товарів

PrestaShop-імпортер очікує фіксований набір полів. Роздільник та кодування настроюються при завантаженні:

ID;Active (0/1);Name *;Categories;Price tax excl.;Tax rules ID;Wholesale price;On sale (0/1);Discount amount;Discount percent;Discount from (yyyy-mm-dd);Discount to (yyyy-mm-dd);Reference #;Supplier reference #;Supplier;Brand;EAN13;UPC;MPN;Ecotax;Weight;Quantity;Description;Short description;Tags (x,y,z...);Meta title;Meta description;URL rewritten;Image URLs (x,y,z...);Image alt texts (x,y,z...);Feature (Name:Value:Position:Customized);Available for order;Available date;Show price;Visibility;Additional shipping cost;Unity;Unit price;Summary;Shop (for multi-shop only)
;1;Зимова чоловіча куртка;Верхній одяг,Чоловічий одяг;2999.00;1;0;0;0;0;;;ART-001;;Бренд;КуртаБренд;4607167430120;;;0;1.5;50;"Повний опис куртки...";"Зимова куртка";"куртка, зима, чоловіча";"Купити зимову чоловічу куртку";"Зимова чоловіча куртка — купити";"zimova-chоlovichа-kurtka";"https://cdn.example.com/img1.jpg,https://cdn.example.com/img2.jpg";"Куртка вид 1,Куртка вид 2";"Колір:Чорний:1:0;Розмір:L:2:0";1;;;1;everywhere;0;;;

Конфігурація для масового імпорту

За замовчуванням PHP-процес імпорту натикається на memory_limit та max_execution_time. Для файлів від 10 000 рядків:

// override/controllers/admin/AdminImportController.php
class AdminImportControllerCore extends AdminImportController
{
    public function __construct()
    {
        parent::__construct();
        @ini_set('memory_limit', '512M');
        @ini_set('max_execution_time', '3600');
    }

    // Зменшення розміру batch для економії пам'яті
    const MAX_LINE_SIZE = 4096;  // байт на рядок
}

Або через настройку PHP-FPM пула для процесів імпорту:

; /etc/php/8.1/fpm/pool.d/prestashop-import.conf
[prestashop-import]
pm = static
pm.max_children = 2
php_value[memory_limit] = 1G
php_value[max_execution_time] = 7200

Програмний імпорт через ObjectModel

Для інтеграції з ERP/1С рекомендується обходити веб-імпортер та працювати прямо через API PrestaShop:

// Імпорт товара з атрибутами
class ProductImporter
{
    private int $defaultLangId;
    private int $shopId;

    public function importProduct(array $data): int
    {
        $product = new Product();
        $product->name[$this->defaultLangId]              = $data['name'];
        $product->description[$this->defaultLangId]       = $data['description'];
        $product->description_short[$this->defaultLangId] = $data['short_description'];
        $product->link_rewrite[$this->defaultLangId]      = Tools::link_rewrite($data['name']);
        $product->reference    = $data['sku'];
        $product->price        = (float) $data['price'];
        $product->weight       = (float) ($data['weight'] ?? 0);
        $product->active       = 1;
        $product->id_category_default = $data['category_id'];
        $product->id_shop_default     = $this->shopId;

        if (!$product->add()) {
            throw new \RuntimeException('Failed to add product: ' . $data['sku']);
        }

        // Прив'язка до категорій
        $product->addToCategories($data['category_ids']);

        // Оновлення залишків
        StockAvailable::setQuantity($product->id, 0, (int) $data['qty']);

        // Індексація після додавання
        Search::indexation(false, $product->id);

        return (int) $product->id;
    }

    public function importImage(int $productId, string $imageUrl, string $legend = ''): void
    {
        $image = new Image();
        $image->id_product  = $productId;
        $image->position    = Image::getHighestPosition($productId) + 1;
        $image->cover       = !Image::getCover($productId);
        $image->add();

        $imageFile = _PS_PRODUCT_IMG_DIR_ . $image->getImgPath() . '.jpg';
        Tools::copy($imageUrl, $imageFile);
        $imageObj = new ImageManager();
        $imageObj->resize($imageFile, $imageFile, null, null, 'jpg', false, $error, null, 95, true);
        Image::generateImgSize($imageFile, $image->id_product, $image->id);
    }
}

Експорт через WebService API

PrestaShop WebService надає REST API для експорту:

# Отримання списку товарів через WebService
curl "https://example.com/api/products?ws_key=YOUR_API_KEY&output_format=JSON&limit=100&page=1&display=full"

# Фільтрація за датою змінення
curl "https://example.com/api/products?ws_key=KEY&output_format=JSON&filter[date_upd]=[2024-01-01,2024-12-31]&date=1"

PHP-клієнт для систематичного експорту:

$client = new PrestaShopWebservice('https://example.com', 'YOUR_API_KEY', false);

$params = [
    'resource' => 'products',
    'display'  => '[id,reference,name,price,quantity]',
    'sort'     => '[id_ASC]',
    'limit'    => '100,100', // offset=100, limit=100
];

$xml = $client->get($params);
$products = $xml->products->product;

Настройка модуля імпорту для cron

Для регулярного оновлення каталогу з зовнішнього джерела:

// modules/erpimport/cron.php
define('_PS_ADMIN_DIR_', getcwd());
include(dirname(__FILE__) . '/../../config/config.inc.php');

$importer = new ErpProductImporter();
$products = $importer->fetchFromErp(strtotime('-1 hour')); // змінені за годину

foreach (array_chunk($products, 100) as $batch) {
    foreach ($batch as $productData) {
        try {
            $importer->upsert($productData);
        } catch (Exception $e) {
            PrestaShopLogger::addLog(
                'ERP import error: ' . $e->getMessage(),
                3, // severity: error
                null, 'Product', $productData['id'] ?? 0
            );
        }
    }
    // Пауза між batch'ами для зменшення навантаження
    usleep(100000); // 100ms
}
# Cron запис
*/30 * * * * www-data php /var/www/prestashop/modules/erpimport/cron.php >> /var/log/prestashop/erp-import.log 2>&1

Графік проекту

  • Настройка вбудованого імпортера + тестовий імпорт: 4–8 годин
  • Розробка користувацького імпортера з ERP-інтеграцією: 3–7 днів
  • Настройка регулярної синхронізації з моніторингом помилок: 2–3 дні
  • Міграція каталогу 10 000+ SKU з зображеннями: 3–7 днів