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


CatalogFill - Загрузка XML из 1С

  • Всем добрый день. Купил модуль CatalogFill. разобрался с загрузкой из Excel. Все супер, автору программы огромное спасибо.
    Но вот возникла потребность загрузки из XML:

    Вот часть конфига связанного с настройкой XML импорта:

    <?php
    
    //Название класса таблицы товаров в БД
    $cf_config['className'] = 'ShopContent';
    //Название пакета таблицы товаров в БД
    $cf_config['packageName'] = 'shop';
    //Название поля ID родителя
    $cf_config['parent_field'] = 'resource_id';
    
    //разбивка по столбцам при импорте и экспорте (content|tv|category)
    /*$cf_config['content_row'] = array(
        array('Код',array('articul','content')),
        array('Категория',array(2,'category')),//3 - ID шаблона категории
        array('Подкатегория',array(3,'category')),//3 - ID шаблона подкатегории
        array('Наименование',array('pagetitle','content')),
        array('Описание',array('content','content')),
        array('Цена',array('price','content')),
        array('Ед. имз',array('unit','content')),
        array('Количество',array('quantity','content')),
        array('Уценка',array('ucenka','content'))
        
      );
    */
    //значения по умолчанию при импорте или проверка при экспорте
    $cf_config['imp_content_default'] = array(
        'content' => array(
            'deleted' => 0,
            'published' => 1,
            'template' => 3  //Шаблон для карточки товара
            //'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'] = 'articul';
    
    //проверять соответствие товара при обновлении по значению 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'] = '/Каталог/Товары';
    
    //Структура XML файла для импорта
    $cf_config['imp_xml_structure'] = <<<EOF
    <Товар>
    				
    				<Артикул>articul</Артикул>
    				<Наименование>pagetitle</Наименование>
    			   <Описание>content</Описание>
    				
    </Товар>
    EOF;
    
    //тестирование конфигурации (без записи в БД). Отчёты -> Журнал ошибок.
    $cf_config['imp_testmode'] = TRUE;
    
    //функция для фильтрации значений при ИМПОРТЕ
    function filter_import($value_arr){
        $output_arr = $value_arr;
       // $output_arr['content']['image'] = NULL;
      /*  if(isset($output_arr['content']['pagetitle']))
            $output_arr['content']['image'] = $output_arr['content']['sortindex'];
        */
        
        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;
    }
    
    
    ?>
    

    Вот сама XML:

    <?xml version="1.0" encoding="UTF-8"?>
    <КоммерческаяИнформация xmlns="urn:1C.ru:commerceml_2" xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" ВерсияСхемы="2.07" ДатаФормирования="2016-06-07T17:12:18">
    	<Каталог>
    		<Товары>
    			<Товар>
    				<Артикул>48477</Артикул>
    				<Наименование>Заготовка - брусок  4х 4х200мм Р6АМ5 HRC 64-66 "CNIC"</Наименование>
    				<Описание>Применяется для изготовления резцов.Твердость HRC64-66</Описание>
    								
    			</Товар>
    			<Товар>
    			
    				<Артикул>48499</Артикул>
    				<Наименование>Заготовка - брусок  5х 5х200мм Р6АМ5 HRC 64-66 "CNIC"</Наименование>
    				<Описание>Применяется для изготовления резцов.Твердость HRC64-66</Описание>
    			
    			</Товар>
    			<Товар>
    			
    				<Артикул>48333</Артикул>
    				<Наименование>Заготовка - брусок  5х</Наименование>
    				<Описание>Применяется для изготовления резцов.</Описание>
    			
    			</Товар>
    		</Товары>
    	</Каталог>
    </КоммерческаяИнформация>
    

    При загрузке вываливаю вот такие ошибки:

    [2016-06-09 14:12:16] (ERROR @ /var/www/seovolga/data/www/b.seovolga.ru/core/components/catalogfill/model/catalogfill.class.php : 1503) PHP warning: Invalid argument supplied for foreach()
    

    Подскажите пожалуйста что я делаю не так?

  • Первое что мне бросилось в глаза

    <Артикул>articul</Артикул>
    

    в modx нет поля articul
    Если нужно чтобы артикул попал в доп поле (В документации про это написано)

    <Options>
            <Stock>tv5</Stock>
            <Image>tv2</Image>
        </Options>
    

    Сам я из xml не выгружал, но еще вложенность может неверно указал

    $cf_config['imp_xml_itemsparent_path'] = '/Каталог/Товары';
    

    Добавь КоммерческаяИнформация/Каталог/Товары

  • У меня таблица MIGX, поле артикул я создал, причем загрузка из XLS прекрасно работает.
    Пробывал добавить -> КоммерческаяИнформация:

    $cf_config['imp_xml_itemsparent_path'] = '/КоммерческаяИнформация/Каталог/Товары';
    

    тоже не работает, та же самая ошибка

  • Я думаю причина в том, что xpath не работает с русским текстом. Вряд ли разработчики библиотеки SimpleXML на такое рассчитывали.

    Но если вы в конфиге сделаете так:

    $cf_config['imp_xml_itemsparent_path'] = '';
    

    А в XML так:

    <Товары>
    	<Товар>
    		<Артикул>48477</Артикул>
    		<Наименование>Заготовка - брусок  4х 4х200мм Р6АМ5 HRC 64-66 "CNIC"</Наименование>
    		<Описание>Применяется для изготовления резцов.Твердость HRC64-66</Описание>			
    	</Товар>
    	<Товар>
    		<Артикул>48499</Артикул>
    		<Наименование>Заготовка - брусок  5х 5х200мм Р6АМ5 HRC 64-66 "CNIC"</Наименование>
    		<Описание>Применяется для изготовления резцов.Твердость HRC64-66</Описание>
    	</Товар>
    	<Товар>
    		<Артикул>48333</Артикул>
    		<Наименование>Заготовка - брусок  5х</Наименование>
    		<Описание>Применяется для изготовления резцов.</Описание>
    	</Товар>
    </Товары>
    

    скорее всего сработает.

 

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

  • Мало информации.
    Вот документация по сниппету getProducts
    https://modx-shopkeeper.ru/docs/shopkeeper-3/snippet-getproducts
    Если ресурс с ID=2 это категория, в которой есть подкатегории, то надо использовать параметр depth.

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

    Пытаюсь вывести товары из категории Товары - ресурсы MODX на демо сайте shk3, стандартный набор параметров цепляет товары только с сетки migx, а с ресурсов не выводит, вставляю такие параметры снипета:

    [[!getProducts? &parents=`2` &limit=`50` &tpl=`product_cart_main` &where=`{"tags:LIKE": "%#новинка#%"}` ]]

    другой снипет нужен?

    Читать далее
  • Я не грубил, а только указал, что вы слишком много хотите. Зачем вы мне предлагаете доступ к админке, чтобы я за вас там всё сделал, а Вы не утруждали себя предоставлением информации? Задавайте конкретный вопрос и ждите ответа. Если вопросов много, то лучше их пронумеровать.

    Если ваш компонент некорректно работает

    Я открыл ваш сайт и первое, что увидел, это JS ошибки, которые не относятся к шопкиперу, а относятся к какому-то слайдеру. То, что у вас локально всё работает, а на сервере не работает для меня эта информация лишняя, она ничего не дает.

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

    Всмысле за меня? Почему вы постоянно грубите? Если ваш компонент некорректно работает, почему я не могу обратиться в поддержку? Форумы постоянно читаю, в том числе этот. Но если сайт компонент работает на одном хостинге но по магическим причинам не работает на другом, когда все остальное работает, что я должен делать?

    Читать далее