Сохранить
Сохраняем
  • Z
    zulya

    @Andchir Спасибо большое! Протестировала. Все работает корректно.

    написал в Поддержка Читать далее
  • Z
    zulya

    Здравствуйте!
    Возникла необходимость формировать pagetitle из нескольких данных в колонках Excel и сохранять их вместе в pagetitle чтобы одинаковые названия не перезаписывали друг друга.
    У меня в экзель файле очень много совпадающих ресурсов по названию. Поэтому при импорте, один перезаписывает другого. Поэтому возникла такая необходимость. Вот пример данных с совпадающими названиями ресурсов:
    alt text

    Вы можете подсказать, Как можно сделать такую настройку в файле чтобы в Modx Revo в pagetitle сохранились по такому шаблону: species brand pagetitle? Вот так:
    0_1543649199389_a951ae3f-1aa3-4584-9178-169760cdcbca-image.png

        array('pagetitle',array('pagetitle','content')),
        array('brand',array(35,'tv')),
        array('species',array(34,'tv')),
    

    Спасибо!

    написал в Поддержка Читать далее
  • Z
    zulya

    Участник @Andchir написал в Экспорт CatalogFill не работает. Ошибка «В выбранной категории нет товаров»:

    Надо обратить внимание на этот параметр

    //значения по умолчанию при импорте или проверка при экспорте
    $cf_config['imp_content_default'] = array(
        'content' => array(
            'published' => 1,
            'template' => 3,
           // 'isfolder' => 1
            //'createdon' => strtotime("now")
        ),
        'tv' => array(
            //7 => 0
        )
    );
    

    Покажите какой ID шаблона у ваших товаров.

    Здравствуйте!
    Оказывается тут

    // 'isfolder' => 1
    

    нужно было убрать комментарий. После этого работает корректно. Спасибо!

    написал в Поддержка Читать далее
  • Z
    zulya

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

    написал в Поддержка Читать далее
  • Z
    zulya

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

    написал в Поддержка Читать далее
  • Z
    zulya

    Здравствуйте!
    У меня тоже аналогичная ситуация. При экспорте дочерних ресурсов одного ресурса-родителя и при использовании такой настройки:

    <?php
    
    //разбивка по столбцам при импорте и экспорте (content|tv|category)
    $cf_config['content_row'] = array(
        array('name',array('pagetitle','content')),
        array('longtitle',array('longtitle','content')),
        array('EngName-Shop',array(35,'tv')),
        array('RusName-Shop',array(34,'tv')),
        array('seo-offer-name',array(32,'tv')),
        array('seo-offer-description',array(33,'tv')),
        array('small-logo',array(1,'tv')),
        array('menutitle',array('menutitle','content')),
    );
    
    //значения по умолчанию при импорте или проверка при экспорте
    $cf_config['imp_content_default'] = array(
        'content' => array(
            'published' => 1,
            'template' => 3,
           // 'isfolder' => 1
            //'createdon' => strtotime("now")
        ),
        'tv' => array(
            //7 => 0
        )
    );
    
    //первая строка - названия полей
    $cf_config['include_captions'] = true;
    
    //число товаров импортируемых за один раз (загрузка по группам). 0 - не ограничивать.
    $cf_config['batch_import'] = 0;
    
    //разбивать по категориям
    $cf_config['include_categories'] = false;
    
    //удалять дочерние категории при очистке и обновлении каталога
    $cf_config['delete_subcategories'] = true;
    
    //по какому полю проверять соответствие товара при обновлении. false - не проверять (очистка категории при обновлении).
    $cf_config['imp_chk_field'] = 'pagetitle';
    
    //проверять соответствие товара при обновлении по значению TV. Указать ID TV. false - не проверять (очистка категории при обновлении).
    $cf_config['imp_chk_tvid_val'] = false;
    
    //Добавлять товары, которые не найдены при обновлении по TV (imp_chk_tvid_val) или полю (imp_chk_field)
    $cf_config['imp_if_not_exist'] = true;
    
    //удалять HTML-теги при экспорте
    $cf_config['exp_strip_tags'] = false;
    
    //автоматически генерировать псевдоним (alias) при импорте
    //false - выключено; true - генерировать с переводом в транслит; 'notranslit' - генерировать без перевода в транслит.
    $cf_config['imp_autoalias'] = false;
    
    //Изменить значения поля для всех вложенных товаров до начала импорта.
    //Например можно отменить публикацию для всех товаров и публиковать только те, которые есть в новом прайс-листе.
    //первый массив - какие поля и на какие значения менять, второй массив - условия которые нужно проверять (можно сделать пустым)
    $cf_config['imp_before_change'] = false;//'[{"tv.inventory":0},{}]';//'[{"published":0},{"tv.pricename":"Поставщик1"}]';//false - для отмены
    
    //удалить файл после экспорта (скачивания)
    $cf_config['exp_delete_file'] = false;
    
    //кодировка CSV-файла при экспорте
    $cf_config['exp_csv_charset'] = 'UTF-8';//'windows-1251'
    
    //Импортировать (обновлять) пустые значения
    $cf_config['imp_empty'] = true;
    
    //Имя файла процессора, который использовать для импорта. Если пусто, используется стандартный процессор "import".
    $cf_config['imp_custom_processor'] = '';
    
    //путь (xpath) в XML структуре до товаров
    $cf_config['imp_xml_itemsparent_path'] = '';//'/catalog/shop/offers'
    
    //Структура XML файла для импорта
    $cf_config['imp_xml_structure'] = '';
    
    //тестирование конфигурации (без записи в БД)
    $cf_config['imp_testmode'] = false;
    
    //функция для фильтрации значений при ИМПОРТЕ
    function filter_import($value_arr){
        $output_arr = $value_arr;
        /*
        if(isset($output_arr['content']['pagetitle']))
            $output_arr['content']['pagetitle'] = mb_strtoupper($output_arr['content']['pagetitle'], 'UTF-8');
        */
        return $output_arr;
    }
    
    
    //функция для фильтрации значений при ЭКСПОРТЕ
    function filter_export($value_arr,$doc_id=0){
        $output_arr = $value_arr;
        //var_dump($value_arr,$output_arr);
        //exit;
        /*
        if(isset($output_arr['price']))
            $output_arr[1] = floatval($output_arr[1]) - 200;
        */
        return $output_arr;
    }
    
    ?>
    

    Вот скриншот ошибки http://dl3.joxi.net/drive/2018/11/17/0003/2897/236369/69/848b164bb3.png
    У меня последняя версия Компонента.

    Помогите разобраться с проблемой! Спасибо!

    написал в Поддержка Читать далее
  • Z
    zulya

    @andchir
    Здравствуйте.
    Нашла файл with categories php.
    $cf_config['content_row'] = array(
    array('Категория',array(3,'category')),//3 - ID шаблона категории
    array('Подкатегория',array(3,'category')),//3 - ID шаблона подкатегории
    array('Наименование',array('pagetitle','content')),
    array('Краткое описание',array('introtext','content')),
    array('Контент',array('content','content')),
    array('Цена',array(1,'tv')),
    array('Кол-во на складе',array(5,'tv')),
    array('Картинка',array(2,'tv'))
    );
    Вы можете подсказать, которая из этих строк является Названием для ресурса-родителя?

    написал в MODX - Вопросы и обсуждения Читать далее
  • Z
    zulya

    Здравствуйте. Мой сайт не интернет магазин, а просто сайт на Modx Revo.
    Возникла необходимость импортировать ресурсы с их дочерними ресурсами. Сделала вручную, но родителей и дочерних ресурсов по 150 каждый. Получается 150 ресурсов родителей с 150 дочерними ресурсами.
    Необходимо импортировать pagetitle, longtitle, menutitle и alias.
    Вы можете привести пример конфигурационного файла и пример экзель файла? Была бы очень признательна. Спасибо!

    написал в MODX - Вопросы и обсуждения Читать далее
  • Z
    zulya

    Причину нашла сама. Проблема была не в конфигурационном файле, а в названии экзель файла. Пересохранила экзель с коротким латинским названием и загрузила через интерфейс CatalogFill и попробовала импортировать. Данные успешно импортировались. Надеюсь, что мой ответ поможет и другим, кто столкнется с ошибкой Error 500 при импорте данных из Экзель (когда никаких ошибок в их конфигурационных файлах нет).

    написал в MODX - Вопросы и обсуждения Читать далее
  • Z
    zulya

    Здравствуйте. На сайте используется версия php 7. А также установлен компонент CatalogFill.
    Создала свой конфигурационный файл:
    <?php

    //разбивка по столбцам при импорте и экспорте (content|tv|category)
    $cf_config['content_row'] = array(
    array('pagetitle',array('pagetitle','content')),
    array('longtitle',array('longtitle','content')),
    array('menutitle',array('menutitle','content')),
    array('alias',array('alias','content'))
    );

    //значения по умолчанию при импорте или проверка при экспорте
    $cf_config['imp_content_default'] = array(
    'content' => array(
    'published' => 1,
    'template' => 64
    //'createdon' => strtotime("now")
    ),
    'tv' => array(
    //7 => 0
    )
    );

    //первая строка - названия полей
    $cf_config['include_captions'] = true;

    //число товаров импортируемых за один раз (загрузка по группам). 0 - не ограничивать.
    $cf_config['batch_import'] = 0;

    //разбивать по категориям
    $cf_config['include_categories'] = false;

    //удалять дочерние категории при очистке и обновлении каталога
    $cf_config['delete_subcategories'] = true;

    //по какому полю проверять соответствие товара при обновлении. false - не проверять (очистка категории при обновлении).
    $cf_config['imp_chk_field'] = 'pagetitle';

    //проверять соответствие товара при обновлении по значению TV. Указать ID TV. false - не проверять (очистка категории при обновлении).
    $cf_config['imp_chk_tvid_val'] = false;

    //Добавлять товары, которые не найдены при обновлении по TV (imp_chk_tvid_val) или полю (imp_chk_field)
    $cf_config['imp_if_not_exist'] = true;

    //удалять HTML-теги при экспорте
    $cf_config['exp_strip_tags'] = false;

    //автоматически генерировать псевдоним (alias) при импорте
    //false - выключено; true - генерировать с переводом в транслит; 'notranslit' - генерировать без перевода в транслит.
    $cf_config['imp_autoalias'] = false;

    //Изменить значения поля для всех вложенных товаров до начала импорта.
    //Например можно отменить публикацию для всех товаров и публиковать только те, которые есть в новом прайс-листе.
    //первый массив - какие поля и на какие значения менять, второй массив - условия которые нужно проверять (можно сделать пустым)
    $cf_config['imp_before_change'] = false;//'[{"tv.inventory":0},{}]';//'[{"published":0},{"tv.pricename":"Поставщик1"}]';//false - для отмены

    //удалить файл после экспорта (скачивания)
    $cf_config['exp_delete_file'] = false;

    //кодировка CSV-файла при экспорте
    $cf_config['exp_csv_charset'] = 'UTF-8';//'windows-1251'

    //Импортировать (обновлять) пустые значения
    $cf_config['imp_empty'] = true;

    //Имя файла процессора, который использовать для импорта. Если пусто, используется стандартный процессор "import".
    $cf_config['imp_custom_processor'] = '';

    //путь (xpath) в XML структуре до товаров
    $cf_config['imp_xml_itemsparent_path'] = '';//'/catalog/shop/offers'

    //Структура XML файла для импорта
    $cf_config['imp_xml_structure'] = '';

    //тестирование конфигурации (без записи в БД)
    $cf_config['imp_testmode'] = false;

    //функция для фильтрации значений при ИМПОРТЕ
    function filter_import($value_arr){
    $output_arr = $value_arr;
    /*
    if(isset($output_arr['content']['pagetitle']))
    $output_arr['content']['pagetitle'] = mb_strtoupper($output_arr['content']['pagetitle'], 'UTF-8');
    */
    return $output_arr;
    }

    //функция для фильтрации значений при ЭКСПОРТЕ
    function filter_export($value_arr,$doc_id=0){
    $output_arr = $value_arr;
    //var_dump($value_arr,$output_arr);
    //exit;
    /*
    if(isset($output_arr['price']))
    $output_arr[1] = floatval($output_arr[1]) - 200;
    */
    return $output_arr;
    }

    ?>
    Но при импорте данных с Экзель, выдает ошибку Error 500.
    Вы можете подсказать, где ошибка в конфигурационном файле? Спасибо!

    написал в MODX - Вопросы и обсуждения Читать далее