Последние темы


CatalogFill: Как импортировать данные из конкретных колонок (столбы) из Эксель?

  • Здравствуйте!
    Можно вас спросить о CatalogFill?

    Почему-то при импорте из эксель (импортировала только из эксель, другие варианты не пробовала), модуль импортирует данные со всех колонок экселя, даже те, которые я не указываю в файле настройки.

    $cf_config['content_row'] = array(
    array('name',array('pagetitle','content')),
    array('advcampaign_name',array(9,'tv')),
    array('logo',array(5,'tv')),
    array('description',array(6,'tv')),
    array('promocode',array(11,'tv')),
    array('gotolink',array(7,'tv')),
    array('date_end',array(8,'tv')),
    array('categories',array(10,'tv'))
    

    Например, колонку name в эксель я указываю как pagetitle. В экселе, это 2 колонка.
    А в 1 колонке эксель есть ID, которого я не указываю в файле настройки модуля, чтобы модуль не импортировал. Эта не нужная колонка.
    А модуль при импорте берет данные из 1 колонки экзель (из ID) и создает ресурсы с такими же pagetitle из колонки ID, а должно создавать ресурсы по данным из колонки name.
    Возникает вопрос, как указать модулю чтобы модуль при импорте НЕ импортировал не нужные колонки эксель, а импортировал только те выше перечисленные колонки?
    Заранее спасибо!

  • Например, колонку name в эксель я указываю как pagetitle. В экселе, это 2 колонка.

    А где вы указываете, что pagetitle нужно брать со второй колонки? Там нет искусственного интеллекта.

    Нужно попробовать так (пример):

    //разбивка по столбцам при импорте и экспорте (content|tv|category)
    $cf_config['content_row'] = array(
        1 => array('Наименование',array('pagetitle','content')),
        4 => array('Краткое описание',array('introtext','content')),
        6 => array('Подробное описание',array('content','content')),
        7 => array('Цена',array(1,'tv'))
    );
    

    Цифры - это номера колонок от нуля.

  • @andchir Здравствуйте. Спасибо, что ответили.
    Я думала, что указав тут:
    array('name',array('pagetitle','content')),
    CatalogFill сам поймет, что Колонка с названием name должна импортироваться в Modx как Pagetitle.
    Теперь попробую ваш вариант настройки. Спасибо!

  • @andchir есть ли решение, при которой значения брались не по номеру столбца а по названиям?

 

Последние комментарии

  • Вот, может кому-то пригодиться. Скачиваем модуль с оф.сайта яндекс кассы. И в YandexMoneyHook,
    core/components/yandexmoney/model/yandexmoney.class.php и /assets/components/yandexmoney/connector_result.php подключаем пакет shopkeeper3 и выбор заказа по id.
    В общем меняем строки для shk2 на shk3.

    $modx->addPackage('shopkeeper', $modx->getOption('core_path').'components/shopkeeper/model/'); $order = $modx->getObject('SHKorder', $order_id) на $modx->addPackage('shopkeeper3', $modx->getOption('core_path').'components/shopkeeper3/model/'); $order = $modx->getObject('shk_order', $order_id);

    Так же, если не меняли стандартные статусы заказа, то в модули их исчисление начинается с 0, в shk3 с 1. Надо учесть это при обновлении статуса при оплате. (я тупо в БД в таблице с параметрами сниппета YandexMoney поменял нумерацию)

    Читать далее
  • Z

    Спасибо, буду пробовать.

    Читать далее
  • Может такая причина
    http://forum.modx-shopkeeper.ru/topic/717/mysql-5-7-не-работает-query-groupby/4

    Смотрите в журнал ошибок.

    Надо выполнить запрос

    SET GLOBAL sql_mode=(SELECT REPLACE(@@sql_mode,'ONLY_FULL_GROUP_BY',''));

    Читать далее
  • Z

    Добрый день! Используется шаблон с id 3. Вот скриншот: http://dl3.joxi.net/drive/2018/11/17/0003/2897/236369/69/3dd12003a9.png

    Читать далее