CatalogFill - почему мешаются тв-поля?



  • Не могу никак понять, почему мешаются тв-поля при импорте...

    Сначала все поля мешались, но в конфиге проставил сначала поля с типом 'content', они теперь совпадают, зато идущие следом тв-поля мешаются в непонятном порядке.
    В ексель-файле около 600 строк. Пробовал разные форматы импортируемого файла.

    Скрин эксель файла:
    0_1504176370328_Microsoft Excel - 2-US.jpg

    Конфигурация:

    <?php
    
    //разбивка по столбцам при импорте и экспорте (content|tv|category)
    $cf_config['content_row'] = array(
        array('pagetitle',array('pagetitle','content')),
        array('alias',array('alias','content')),
        array('menuindex',array('menuindex','content')),
        array('articul',array(1,'tv')),
        array('fs',array(8,'tv')),
        array('stream',array(20,'tv')),
        array('genre',array(9,'tv')),
        array('logoimg',array(13,'tv')),
        array('phone',array(16,'tv')),
        array('adress',array(4,'tv')),
        array('city',array(3,'tv')),
        array('country',array(6,'tv')),
        array('email',array(17,'tv')),
        array('site',array(19,'tv')),
    );
    
    
    //значения по умолчанию при импорте или проверка при экспорте
    $cf_config['imp_content_default'] = array(
        'content' => array(
            'published' => 1,
            'template' => 2,
            'class_key' => 'Ticket',
            'show_in_tree' => 0,
            'createdon' => time(),
            'publishedon' => time(),
            'pub_date' => time(),
            'createdby' => $modx->user->id,
            'publishedby' => $modx->user->id,
        ),
        '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'] = 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'] = <<<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;
    }
    
    ?>
    

    В тестовом режиме пишет в логи следующий бред:

    [2017-08-31 13:34:45] (ERROR @ /***/core/components/catalogfill/model/catalogfill.class.php : 873) Array
    (
        [content] => Array
            (
                [published] => 1
                [template] => 2
                [class_key] => Ticket
                [show_in_tree] => 0
                [createdon] => 1504175685
                [publishedon] => 1504175685
                [pub_date] => 1504175685
                [createdby] => 4
                [publishedby] => 4
                [pagetitle] => chilltrax
                [alias] => chilltrax
                [menuindex] => 2
                [context_key] => web
                [parent] => 134
            )
    
        [tv] => Array
            (
                [1] => wb0002 // ВЕРНО
                [8] => c // ВЕРНО
                [20] => // НЕПОНЯТНО
                [9] => US // ТУТ ПОЛЕ genre (9), А ИМПОРТИРОВАЛОСЬ country (6)
                [13] => miami // logoimg (13), А ИМПОРТИРОВАЛОСЬ city (3)
                [16] => chilltrax.com // phone (16), А ИМПОРТИРОВАЛОСЬ site (19)
                [4] => chill@chilltrax.com // adress (4), А ИМПОРТИРОВАЛОСЬ email (17)
                [3] => 10818 nw 51st lane miami, fl 33178 // city (3), А ИМПОРТИРОВАЛОСЬ adress (4)
                [6] => chillout // country (6), А ИМПОРТИРОВАЛОСЬ genre (9)
                [17] => 800.576.7316 // email (17), А ИМПОРТИРОВАЛОСЬ phone (16)
                [19] => assets/images/webradio/chilltrax-180.jpg  // site (19), А ИМПОРТИРОВАЛОСЬ logoimg (13)
            )
    
    )
    

    Понятное дело количество колонок в файле и в конфигурации совпадает.

    Может быть дело в поле stream из-за каких-то знаков, например точки с запятой? (пример значения: http://server1.chilltrax.com:9000/;stream.nsv).

    Пробовал импортировать файл из 3-х строк, результат тот же:
    0_1504177702233_Редактируем 977 todays hits  Radio online - Google Chrome.jpg

    Куда ещё смотреть? Пару дней уже убил на настройку этого компонента...

    P.S. Забыл сказать, что импортирую в Tickets, но это сути не меняет, в обычных ресурсах та же проблема.
    Прикрепляю пробный файл из 3-х строк: [0_1504178027960_3-US.xlsx](Загрузка 100%) прикрепить файл не могу, пишет что у меня недостаточно прав для этого действия...



  • Куда копать, чтобы решить эту проблему?


  • Администраторы

    array('fs',array(8,'tv')),
    array('stream',array(20,'tv')),
    

    В файле на вашей картинке видно, что после "fs" идет "country", а не "stream". Дальше порядок тоже не совпадает.



  • @Andchir ой, видно я не тот файл конфигурации выложил, у меня их за время тестов набралось целая дюжина, извини.

    Только что нашел ответ на свой вопрос: всё у меня было правильно везде, оказывается файл импорта был бракованный - после колонки fs была спрятана ещё одна колонка. То есть её оказывается когда-то задвинули за fs и невооруженным глазом видна одна колонка, а там их две.
    Определил это включив в конфигурационном файле тестовый режим + отключил первую строку с полями и в логи мне распечатало все названия столбцов из первой строки, в том числе и спрятанного.

    Извините за беспокойство, но кому-то это может быть полезно, спасибо за замечательный компонент!



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

Похоже, подключение к Форум | MODX Shopkeeper было разорвано, подождите, пока мы пытаемся восстановить соединение.