Настройка импорта/экспорта товаров 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;"Полное описание куртки...";"Куртка зимняя";"куртка, зима, мужская";"Купить куртку зимнюю мужскую";"Куртка зимняя мужская — купить";"kurtka-zimnyaya-muzhskaya";"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
            );
        }
    }
    // Пауза между батчами для снижения нагрузки
    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 дней