1114 2

Импорт из CSV в MODX, импорт в miniShop2

Особенности:

  1. Это не сниппет, это самодостаточный скрипт.
  2. Использует процессоры для импорта ресурсов и изображений.
  3. Умеет обновлять ресурсы по указанному ключевому полю.
  4. Поддерживает ТВ параметры и поля товаров, включая JSON типа size и color.
  5. Есть режим отладки, с подробным логом и обработкой только первой строки файла.
  6. Выводит сообщения через системный лог.

Теретически, можно импортировать не только товары, но и категории или другие ресурсы, но не проверял.

Скрипт входит в состав miniShop2 с версии 2.1.4 и лежит в /core/components/minishop2/import/csv.php. Запускать его можно как из браузера (если у вас открыта директория core), так и из консоли.

Если захотите его перенести в другое, более подходящее место, то нужно отредактировать строку

require_once dirname(dirname(dirname(dirname(__FILE__)))) . '/config/config.inc.php';

и указать другой путь для получения config.inc.php.

Если вы запускаете скрипт из core, и вообще, если у вас открыта core всем гостям — то вы сам себе злобный буратина. Это небесопасно, я вас предупредил!

Параметры

Параметры можно указывать двумя путями: через командную строку и через массивы $_GET или $_POST

  • file — путь к импортируемому файлу, от корня сайта. Например «core/import/file.csv»
  • fields — строка с полями испортируемого файла.
    Здесь нужно перечислить имена, как они идут в файле. Например: «alias,article,pagetitle,price,image,discount».
    В параметре и файле можно использовать не только поля ресурса, но и:
    • Массивы свойств товара: «size,size,size,color,color»
    • Изображения для галереи: «gallery,gallery,gallery»
    • ТВ параметры (слово «tv» + id параметра): «tv1,tv2,tv3»
  • update — указывает, нужно ли обновлять ресурсы. Значения 1 или 0.
  • key — если включено обновление, обязательно нужно указать ключ товара, по которому определяется его уникальность. Например «article».
  • debug — Режим отладки. Если = 1, то скрипт подробно обрабатывает первую строку файла и выходит.
  • delimeter — Разделитель колонок в csv файле, по умолчанию ";".

Если вы загружаете изображения в галерею, я рекомендую указать товарам id медиа источника source, чтобы не получить кучу картинок в корне сайта.

Примеры

Импорт через консоль:

php ./core/components/minishop2/import/csv.php "file.csv" "article,pagetitle,tv1,size,size,gallery,gallery,tv3" 1 "article" 1 "|"

Импорт через браузер

http://mysite.com/core/components/minishop2/import/csv.php?file=file.csv&fields=article,pagetitle,tv1,size,size,gallery,gallery,tv3&update=1&key=article&debug=1&delimeter=|

В конце работы скрипт выведет статистику и ошибки, если есть.

Комментарии ()

  1. Игорь 14 июля 2022, 10:09 # 0
    Подходит для импорта любых ресурсов, главное указать нужный class_key.
    Можно не устанавливать minishop, а просто скачать файл csv.php
    1. Fox 10 января 2023, 15:58 # 0
      :like

    Главные события игровой индустрии

    Свежие обзоры

    Активация клиента службы управления ключами (KMS) и ключи продуктов (01.2023)

    Универсальные ключи многократной установки (GVLK)

    29 января 2023, 15:31

    Как скачать последнюю стабильную версию автономного установщика Яндекс.Браузера

    Чтобы скачать последнюю стабильную версию автономного установщика Яндекс.Браузера, откройте ссылку...

    23 января 2023, 13:35

    Обзор ноутбука Xiaomi RedmiBook Pro 15 (2021 Ryzen Edition)

    RedmiBook Pro 15: стильный металлический корпус, шикарный дисплей на 3.2K, производительный восьмиядерный процессор AMD Ryzen 7 и 16 ГБ ОЗУ.

    21 мая 2022, 12:45

    Активация клиента службы управления ключами (KMS) и ключи продуктов (2022)

    Универсальные ключи многократной установки (GVLK)

    16 мая 2022, 16:48

    Как сделать задержку перед выполнением скрипта?

    Чтобы js код выполнялся через определенное время после загрузки страницы используем setTimeout

    12 мая 2022, 16:33

    Все обзоры