Новости

Импорт CatalogFill 2.4.10

  • Добрый день! Подскажите пожалуйста по импорту, где можно почитать инструкцию подробную по импорту и экспорту!?

    У меня у сайта такая иерархия Каталог - Материал - Фабрика - Коллекция - Товар

    Когда выбираю "Коллекция" все нормально импортирует т.е. обновляет цены! А когда показываю выше категорию "Фабрика" он не меняет цены почему то((

    Конфиг у меня такой , что посоветуете добавить в него! Спасибо!

    <?php
    
    //разбивка по столбцам при импорте и экспорте (content|tv|category)
    $cf_config['content_row'] = array(
        array('ID',array(id,'content')),                             //id товара
        array('Наименование',array('pagetitle','content')),
     //   array('Краткое описание',array('introtext','content')),
     //   array('Подробное описание',array('content','content')),
        array('Описание title',array(6,'tv')),
        array('Цена',array(3,'tv')),
        //array('Кол-во на складе',array(5,'tv')),
        //array('Картинка',array(2,'tv'))
    );
    
    //значения по умолчанию при импорте или проверка при экспорте
    $cf_config['imp_content_default'] = array(
        'content' => array(
            'deleted' => 0,
            'published' => 1,
            'template' => 2// ID шаблона товара
            //'description' => '',
            //'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'] = true;
    
    //удалять дочерние категории при очистке и обновлении каталога
    $cf_config['delete_subcategories'] = true;
    
    //по какому полю проверять соответствие товара при обновлении. false - не проверять (очистка категории при обновлении).
    $cf_config['imp_chk_field'] = 'id';
    
    //проверять соответствие товара при обновлении по значению 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;
        /*
        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;
    }
    
    ?>
    

    0_1583154892392_222.jpg
    0_1583154925285_шаблон + ТВ.jpg

  • Когда выбираю "Коллекция" все нормально импортирует т.е. обновляет цены! А когда показываю выше категорию "Фабрика" он не меняет цены почему то((

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

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

    Так делать не рекомендуется, потому что id ресурсов могут меняться. Нужно искать по названию или артикулу (TV).

  • Понятно, немного сменю тему, я когда экспортирую он почему, то поле оставляет пустым, не видит он категории, хотя я ему показал шаблоны категорий!

    т.е. "Категория" и "Подкатегория" странно!

    <?php

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

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

    Это я тоже поменял по вашим рекомендациям

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

    Импорт как настрою, заведу товарам артикулы, что бы удобнее было!

  • Если без категорий, то в файле должен быть ID категории - поле"parent".

    я когда экспортирую он почему, то поле оставляет пустым, не видит он категории, хотя я ему показал шаблоны категорий!

    Это не относится к импорту.

  • Я правильно понял!?

    <?php

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

    );

    Или тут надо поиск $cf_config['imp_chk_field'] = 'content';?

  • Вроде импортирует по такой конфигурации

    <?php

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

    );

    Если ставишь $cf_config['imp_chk_field'] = 'id'; то все нормально, если выбрать 'content не хочет не в какую в категориях! Думаю надо завести артикулы!

 

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

  • @Andchir Спасибо!!!
    Все перепробовал кроме [[+note]]
    В письме со статусом отправлен, чтобы трек-номер отправлять покупателю. Все работает. Еще раз спасибо.

    Читать далее
  • в письме только код отображается.

    В каком письме? В письме, которое отправляется при оформлении заказа или, которое при изменении статуса заказа?

    [[+note]]

    Так пробовали?

    Читать далее
  • Доброго времени суток!
    Может кто подскажет как в письме из shk добавить поле {{order.note}}, все варианты перепробовал, в письме только код отображается.

    Читать далее
  • Используйте функцию filter_import() в конфиге. Там есть пример использования.

    Читать далее