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


CatalogFill и filter_export

  • Добрый день, нужно соединить 3 тв поля в поле pagetitle, пытаюсь делать через filter_export, но не хочет работать, глянул как делать для импорта

    tv 11 - Вес
    tv 6 - Цена
    подскажите в чем проблема, спасибо заранее, уже поразному вписывал значение и через $output_arr['tv']['6'] и просто название $output_arr['price'] вообще не хочет работать
    modx 2.7.1
    catalogfill 2.4.10-pl

    //функция для фильтрации значений при ЭКСПОРТЕ
    function filter_export($value_arr,$doc_id=0){
    	
        $output_arr = $value_arr;
        //var_dump($value_arr,$output_arr);
        //exit;
    	  if(isset($output_arr['pagetitle'])) {
    $output_arr['pagetitle'] = $output_arr['pagetitle'] . ' '. $output_arr[11]  . ' '. $output_arr[6];
    	 }
        return $output_arr;
    } 
    
  • При экспорте поля и значения ТВ параметров разделены, поэтому соединить можно только поля или ТВ отдельно. Поля с ТВ нельзя.

  • @Andchir спасибо за ответ, а никак их соединить нельзя будет? если например прямой sql запрос попробовать сделать?
    П.С., а где смотреть весь код который делаешь? например через print_r или var_dump?

  • Вы первый, кто хочет соединить при экспорте. Обычно соединяют и т.п. при импорте. Там есть возможность соединить поля и ТВ.

    П.С., а где смотреть весь код который делаешь? например через print_r или var_dump?

    Открывайте файл catalogfill.class.php в текстовом редакторе и ищите где вызывается функция filter_export().

  • @Andchir еще хотел спросить, как можно реализовать разделение столбцов при экспорте тип ввода ТВ param-edit, в экселе выводит видalt text нужно через разделитель || сделать 2 столбца и т.д., я понимаю что нужно через 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;
    }
    
  • Участник @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;
    }
    

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

 

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

  • @Yiliy

    то есть без имени

    Видимо потому что у вас отключено, а в XML алиаса я не увидел

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

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

    Проблема была оказывается в том, что оно не видело
    <Title>pagetitle</Title>
    Я поменял на
    <Title><item>pagetitle</item></Title>
    и все импортировалось успешно но теперь в каталогах вместо url ресурсов отображается /сайт/каталог/.html
    то есть без имени и после перехода на страницу товара появляется ошибка 403

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

    Поменялся дизайн.
    Новая корзина, всплывающие окна и прочие фишки сверстаны. Нужно переподключить, разобраться с возможным конфликтом JS.
    Что, где и как лежит -- покажу.

    Скайп mas_hate

    Читать далее
  • В $cf_config['imp_xml_structure'] должен быть XML, который в файле повторяется. Также нужно настроить
    параметр $cf_config['imp_xml_itemsparent_path']. Покажите полный файл, который импортируете.

    Читать далее