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


CatalogFill пустые TV

  • Всем привет!

    Если кто сталкивался подскажите:

    CatalogFill - при экспорте правильно выгружает TV параметры.

    При реимпорте этой выгрузки - пустые TV поля. В чем может быть загвоздка? Файл конфига один и тот-же.

    И кто сталкивался - если фотографии товара сделаны через поле MIGX - чтобы импортировать новые фотографии нужно писать конструктор JSON? Или есть уже готовые решения?

    Спасибо!

  • Покажите конфиг.

  • <?php
    
    //разбивка по столбцам при импорте и экспорте (content|tv|category)
    $cf_config['content_row'] = array(
        //array('Артикул',array(9,'tv')),
        array('Наименование',array('pagetitle','content')),
        array('Краткое описание',array('introtext','content')),
        array('Подробное описание',array('content','content')),
        array('Title',array('longtitle','content')),
        array('description',array('description','content')),
        array('Категория',array('parent','content')),
        array('Производитель',array('manuf','tv')),
        array('Цена',array('price','tv')),
        array('Фото превью',array('img','tv')),
        array('Все фото',array('resourcealbum','tv')),
        array('Шаблон',array('template','content')),
        //array('Цена',array(6,'tv')),
        //array('Кол-во на складе',array(5,'tv')),
        //array('Картинка',array(2,'tv'))
    );
    
    //значения по умолчанию при импорте или проверка при экспорте
    $cf_config['imp_content_default'] = array(
        'content' => array(
            // 'class_key' => 'msProduct',
            'deleted' => 0,
            'published' => 1,
            //'template' => 8
            //'createdon' => strtotime("now")
            //'publishedon' => strtotime("now")
            //'pub_date' => strtotime("now")
            //'editedby' => 1
            //'editedon' => strtotime("now")
        ),
        'tv' => array(
            //7 => 0
        )
    );
    
    //первая строка - названия полей
    $cf_config['include_captions'] = true;
    
    //число товаров импортируемых за один раз (загрузка по группам). 0 - не ограничивать.
    $cf_config['batch_import'] = 300;
    
    //разбивать по категориям
    $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'] = true;
    
    //Изменить значения поля для всех вложенных товаров до начала импорта.
    //Например можно отменить публикацию для всех товаров и публиковать только те, которые есть в новом прайс-листе.
    //первый массив - какие поля и на какие значения менять, второй массив - условия которые нужно проверять (можно сделать пустым)
    $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'] = <<<EOF
    <Good>
        <Kod>tv8</Kod>
        <Name>pagetitle</Name>
        <Options>
            <Stock>tv5</Stock>
            <Image>tv2</Image>
        </Options>
        <Prices>
            <RegularPrice>tv1</RegularPrice>
            <OldPrice>tv20</OldPrice>
        </Prices>
    </Good>
    EOF;
    
    //тестирование конфигурации (без записи в БД). Отчёты -> Журнал ошибок.
    $cf_config['imp_testmode'] = false;
    
    //функция для фильтрации значений при ИМПОРТЕ
    function filter_import($value_arr){
        $output_arr = $value_arr;
        // mail('messir@messir.org', 'Debug', json_encode($output_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;
    }
    
    ?>
    
  • При реимпорте этой выгрузки - пустые TV поля.

    Уточните что это значит. Вы делаете экспорт товаров, а потом делаете импорт этих же товаров в эти же категории и получаете очищенные TV параметры? Или импорт делаете после очисти категорий (или в новый каталог)?

  • В отдельную пустую категорию загружаю новый файл импорта, заполненный по образу. В результате TV пустые.
    Далее для теста - выгрузил товары с рабочей категории, перезалил в новую пустую категорию - опять TV пустые. В сам файл TV экспортируются заполненные.

  • Покажите скриншот, чтобы было понятно где вы смотрите заполненность ТВ параметров.

  • array('Цена',array('price','tv')),
    array('Фото превью',array('img','tv')),
    

    Не понятно каким образом у вас работает экспорт, но здесь нужно указывать ID TV параметров, а не их имена. Смотрите примеры конфигурации.

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

    Цитата из документации:

    Для импорта и экспорта TV-параметров (таблица "site_tmplvar_contentvalues" в БД) нужно указать название столбца в файле, ID TV-параметра и тип содержимого.

    Пример:

    2 => array('Цена',array(7,'tv'))

  • Кажется мы нашли причину, вероятно дело в MIGX, при импорте не видит соответствий по id.

    https://yadi.sk/d/-xGpcw5AQanqZg скриншот экспорта, цена, производитель заполнены. а они обычные TV!
    0_1544439651757_2018-12-10 13.59.32.jpg

  • У товаров, созданных через MIGX, не может быть никаких TV-параметров. Разберитесь что такое MIGX, TV-параметры и ресурсы (документы) MODX. В комплекте CatalogFill есть отдельный пример конфигурационного файла для MIGX, но вы используете не его.

  • Так у нас сами товары созданы как обычные ресурсы. Но у товара есть поле "фотографии" на migx

  • Фотографии, как я понял, это второй вопрос. Я по нему пока ничего не отвечал и не просил информации. Это не отменяет того, что в вашем конфиге есть ошибка, о которой я писал выше. Не нужно задавать разные вопросы в одной теме, чтобы не было путаницы.
    http://forum.modx-shopkeeper.ru/topic/15/рекомендации-по-оформлению-темы-с-вопросом

 

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

  • A

    Участник @Andchir написал в CatalogFill и filter_export:

    нужно через разделитель || сделать 2 столбца и т.д.

    Создаете дополнительную колонку (можно несколько) после ТВ, значение которого нужно разделить. ID ТВ для такой колонки можно указать, тот которого не существует.

    //разбивка по столбцам при импорте и экспорте (content|tv|category) $cf_config['content_row'] = array( ... array('Параметры товара', array(2, 'tv')), array('Параметры товара - вторая колонка', array(2000, 'tv'))// Дополнительная колонка в экселе );

    Далее в конфигурационном файле разделяете с помощью функции filter_export().

    //функция для фильтрации значений при ЭКСПОРТЕ function filter_export($value_arr, $doc_id=0){ $output_arr = $value_arr; if(!empty($output_arr[2])) { $tmp = explode('||', $output_arr[2]);// Разделяем строку, получаем массив if (count($tmp) >= 2) { $output_arr[2] = $tmp[0]; $output_arr[2000] = $tmp[1]; } } return $output_arr; }

    работает отлично, спасибо

    Читать далее
  • нужно через разделитель || сделать 2 столбца и т.д.

    Создаете дополнительную колонку (можно несколько) после ТВ, значение которого нужно разделить. ID ТВ для такой колонки можно указать, тот которого не существует.

    //разбивка по столбцам при импорте и экспорте (content|tv|category) $cf_config['content_row'] = array( ... array('Параметры товара', array(2, 'tv')), array('Параметры товара - вторая колонка', array(2000, 'tv'))// Дополнительная колонка в экселе );

    Далее в конфигурационном файле разделяете с помощью функции filter_export().

    //функция для фильтрации значений при ЭКСПОРТЕ function filter_export($value_arr, $doc_id=0){ $output_arr = $value_arr; if(!empty($output_arr[2])) { $tmp = explode('||', $output_arr[2]);// Разделяем строку, получаем массив if (count($tmp) >= 2) { $output_arr[2] = $tmp[0]; $output_arr[2000] = $tmp[1]; } } return $output_arr; }

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

    @Andchir еще хотел спросить, как можно реализовать разделение столбцов при экспорте тип ввода ТВ param-edit, в экселе выводит видalt text нужно через разделитель || сделать 2 столбца и т.д., я понимаю что нужно через filter_export, можете подсказать, спасибо

    Читать далее
  • Покажите скриншот, чтобы было видно что вы вводите в значение по умолчанию.

    Читать далее