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


CatalogFill 2.4.5

  • @semenov80 да. Там указывается общеие данные для позиции товара. Шаблон, публикация и тп

  • спасибо, насчет пустых полей очень вовремя, тоже бы не обратил внимание:)
    пара вопросов еще осталась, а так кажется все просто:

    1. Дата публикации - она автоматом присвоится текущей?
    2. TV с именем uri в таблице content есть - оно само сгенерируется по parent и allias?
    3. Поле content, где куча всяких таблиц, подробных описаний и чанков - по вашему опыту его проще уже в импортированных товарах ручками править или как-то в файл для импорта загонять можно?
    4. Строковое значение в полях по умолчанию задавать просто в кавычках?

    //значения по умолчанию при импорте
    $cf_config['imp_content_default'] = array(
    'content' => array(
    'type' => "document"

  • @semenov80 дата публикации автоматом. Uri это полная ссылка на позицию с алиасом состоящем из наименования, я его выгружаю только на случай 301 редиректа если структуру магазина меняем. Было дело ссылки сдохли в поисковиках.
    Content - если правок много то через файл, по крайней мере в екселе можно замену массовую делать. Если пара правок, то через ресурс.
    Таблицы стараюсь в тв выносить, в текстовые области, а их уже в контент. Хз, правильно или нет, но чище, да и шаблонно.

  • По строковому значению не подскажу. А зачем указывать тип?

  • @Mihail ну я думал все значения из таблицы загонять надо по товару

  • экспорт идет, а импорт и обновление нет - какие-то права доступа к папкам надо править?

  • да, импорт и внесение изменений не работает совсем, только экспорт. ни ошибок ни изменений в товарах(
    еще есть параметр "номер строки" по умолчанию 0. Он на что влияет? Не нашел про него в документации

  • @semenov80 сделайте экспорт, в этом файле внесите изменения, импортируйте. В конфиге стоит по какому полю сравнивать при обновлении?

  • @Mihail
    Да, я так и сделал. В конфиге вписал поле, которое неизменно осталось после редактирования строк (Pagetitle изменил). В итоге ошибки выдало:

    Resource URI catalog/test/kopiya-icp-das-i-7005.html already exists for resource id = 1126; skipping duplicate resource URI for resource id = 862

    Resource URI catalog/test/kopiya-icp-das-i-7011pd.html already exists for resource id = 1124; skipping duplicate resource URI for resource id = 863

    Я так понял pagetitle меняется - сразу allias и uri меняется, и модуль ругается на то что id прежний, а страница другая

  • @semenov80 написано что ресурс с таким урл уже существует, вы пытаетесь сделать дубль.

  • @Mihail ага, тоже читаю и не пойму почему пытается создать новый. я пытаюсь обновить...
    импорт/обновить выбираю

  • Сам конфиг вот (pagetitle изменяю, для обновления использую introtext (оно неизменно). Видимо от изменения pagetitle менятся allias и uri - поэтому ошибка?

    <?php
    
    //разбивка по столбцам при импорте и экспорте (content|tv|category)
    $cf_config['content_row'] = array(
          array('Pagetitle',array('pagetitle','content')),
          array('longtitle',array('longtitle','content')),
          array('description',array('description','content')),
          array('introtext',array('introtext','content')),
          array('Подробное описание',array('content','content')),
          array('Цена',array(1,'tv')),
      array('Ключевые слова',array(13,'tv')),
      array('Аналоговые вводы',array(43,'tv')),
      array('Аналоговые выводы',array(44,'tv')),
      array('Дискретные вводы',array(45,'tv')),
      array('Дискретные выводы',array(46,'tv')),
      array('Серия',array(48,'tv'))
        //array('Кол-во на складе',array(5,'tv')),
        //array('Картинка',array(2,'tv'))
    );
    
    //значения по умолчанию при импорте или проверка при экспорте
    $cf_config['imp_content_default'] = array(
        'content' => array(
            'deleted' => 0,
            'published' => 1,
            'template' => 3,
          'parent' => 860
            //'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'] = 500;
    
    //разбивать по категориям
    $cf_config['include_categories'] = false;
    
    //удалять дочерние категории при очистке и обновлении каталога
    $cf_config['delete_subcategories'] = true;
    
    //по какому полю проверять соответствие товара при обновлении. false - не проверять (очистка категории при обновлении).
    $cf_config['imp_chk_field'] = 'introtext';
    
    //проверять соответствие товара при обновлении по значению 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;
    }
    
    ?>
    
  • В ошибке указаны ид товаров, которые вы хотите продублировать. Сравните.

  • @Mihail в ошибку скопировал пару строк, а так все 259 товаров которые обновлял - все попытались задублироваться, одинаковые записи

  • убрал генерацию алиасов (поставил false) - в итоге задублировались ресурсы вместо обновления. при обновлении разве не перезаписываются редактируемые?

  • если правильно разобрался, то здесь надо фалс вместо тру ставить при обновлении, тогда дубликаты не лезут:

    //Добавлять товары, которые не найдены при обновлении по TV (imp_chk_tvid_val) или полю (imp_chk_field)
    $cf_config['imp_if_not_exist'] = true;
    
  • @semenov80 нет, в случае false вы не зальете новые товары, одновременно с обновлением, например наличия или цен, старых.
    Сравнение товаров идет по указанному вами полю в $cf_config['imp_chk_field'] = 'introtext'; или по какому либо ТВ, обычно артикул.
    Почему у вас сравнение не по Pagetitle? Алиас формируется из pagetitle, если у двух товаров будут одинаковые pagetitle - будут ошибки про дубли. У вас одинаковые pagetitle?

  • @Mihail проблема одинаковых pagetitle это проблема дружественных УРЛ. Для обхода дубликатов урл нужно использовать какие то костыли, я например вписал в код CatalogFill генерацию чисел в конце алиаса.

  • @Mihail pagetitle - разные. новый pagetitle задаю в ексель
    introtext - не меняю, так подумал что по нему надо сравнение делать
    так как pagetitle изменяю, то генерируется новый allias, отсюда наверное и появляется дубль страницы
    отключил генерацию алиасов, отключил создание новых по тв - обновилось без дублей

    одинаковых pagetitle нет в проекте, все уникальные

  • @semenov80 если pagetitle разные, разные и урл. Дублей быть не может, но судя по ошибке, урлы одинаковые. Может вы заливаете экспортируемый файл в какую нибудь тестовую директорию? В этом случае товары одинаковые, в самом проекте и в тестовой.

 

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

  • @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']. Покажите полный файл, который импортируете.

    Читать далее