Сохранить
Сохраняем
  • Y
    Yiliy

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

    написал в Общие вопросы Читать далее
  • Y
    Yiliy

    В чем может быть проблема?

    написал в Общие вопросы Читать далее
  • Y
    Yiliy

    Big и Small Images могут быть от 1 до 10, Summary иногда имеет внутри текст и выглядит так:

    <Summary>
      <item>текст</item>
    </Summary>
    

    написал в Общие вопросы Читать далее
  • Y
    Yiliy

    Не импортируются товары из Xml, вместо них выводит такие ошибки:

    Invalid argument supplied for foreach()
    SimpleXMLElement::xpath(): Invalid expression
    PHP warning: SimpleXMLElement::xpath(): xmlXPathEval: evaluation failed
    PHP warning: current() expects parameter 1 to be array, boolean given

    Вот как выглядит строка товара xml:
    <root>

    <Big_Images>
    <Big_Images0>url to img</Big_Images0>
    <Big_Images1>url to img</Big_Images0>
    </Big_Images>
    <Small_Images>
    <Small_Images0>url to img</Small_Images0>
    <Small_Images1>url to img</Small_Images1>
    </Small_Images>
    <Title>рандомное имя</Title>
    <Summary/>
    <Price>7.43</Price>
    <Main_Info><item>много html кода</item></Main_Info>
    </root>
    

    И вот сам php файл для импорта:

    <?php
    
    //разбивка по столбцам при импорте и экспорте (content|tv|category)
    //$cf_config['content_row'] = array(
        //array('Title',array('pagetitle','content')),
        //array('Title',array(43,'tv')),
        //array('Big_Images',array(44,'tv')),
        //array('Price',array(45,'tv'))
    //);
    //значения по умолчанию при импорте или проверка при экспорте
    $cf_config['imp_content_default'] = array(
        'content' => array(
            'deleted' => 0,
            'published' => 1,
            'description' => '',
            'show_in_tree' => 0,
            'class_key' => 'msProduct',
            'template' => 8 // ID шаблона товара
            //'createdon' => strtotime("now")
            //'publishedon' => strtotime("now")
            //'pub_date' => strtotime("now")
            //'editedby' => 1
            //'editedon' => strtotime("now")
        ),
        'tv' => array(
            //7 => 0
        )
    );
    
    //первая строка - названия полей
    $cf_config['include_captions'] = false;
    
    //число товаров импортируемых за один раз (загрузка по группам). 0 - не ограничивать.
    $cf_config['batch_import'] = 0;
    
    //разбивать по категориям
    $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'] = false;
    
    //удалять 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
    <root>
        <Big_Images>
            <Big_Images0>tv44</Big_Images0>
            <Big_Images1>tv48</Big_Images1>
            <Big_Images2>tv49</Big_Images2>
            <Big_Images3>tv50</Big_Images3>
            <Big_Images4>tv51</Big_Images4>
            <Big_Images5>tv52</Big_Images5>
            <Big_Images6>tv53</Big_Images6>
            <Big_Images7>tv54</Big_Images7>
            <Big_Images8>tv55</Big_Images8>
            <Big_Images9>tv56</Big_Images9>
        </Big_Images>
        <Small_Images>
            <Small_Images0>tv47</Small_Images0>
            <Small_Images1>tv58</Small_Images1>
            <Small_Images2>tv59</Small_Images2>
            <Small_Images3>tv60</Small_Images3>
            <Small_Images4>tv61</Small_Images4>
            <Small_Images5>tv62</Small_Images5>
            <Small_Images6>tv63</Small_Images6>
            <Small_Images7>tv64</Small_Images7>
            <Small_Images8>tv65</Small_Images8>
            <Small_Images9>tv66</Small_Images9>
        </Small_Images>
        <Title>pagetitle</Title>
        <Summary>
            <item>tv57</item>
        </Summary>
        <Price>tv45</Price>
        <Main_Info>
            <item>tv46</item>
        </Main_Info>
    </root>
    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;
    }
    
    ?>
    

    написал в Общие вопросы Читать далее
  • Y
    Yiliy

    Размер БД на хостинговом тарифе - безлимит, впрочем я уже обратился и жду ответа с их стороны.

        php_value memory_limit 256M
    

    Как считаете, какое будет оптимальное количество под 200 к?
    Просто когда я ставил хоть 256 хоть 512 - в админ панели хостинга все равно могло сьедатся вплоть до 2.5 гб из 3.

    написал в MODX - Вопросы и обсуждения Читать далее
  • Y
    Yiliy

    Я долго мучался с настройкой htaccess, но постоянно выводится либо Error -1(до чистки кеша из includes), либо Error 500(после чистки). Так же первый раз когда сегодня заполнял...

    Строки которые добавил в htaccess были такого вида:
    php_value max_execution_time 86400
    php_value max_input_time 86400
    php_value upload_max_filesize 1G
    php_value post_max_size 1G
    php_value memory_limit 256M

    ... в логах выпала такая ошибка:
    [2019-08-28 07:32:04] (ERROR @ /home/мой никнейм/название сайта/core/xpdo/om/xpdoobject.class.php : 240)
    Array
    (
    [0] => HY000
    [1] => 2006
    [2] => MySQL server has gone away
    )
    [2019-08-28 07:32:04] (ERROR @ /home/asdqwrfc/ch-top.com/core/xpdo/om/xpdoobject.class.php : 1452)
    INSERT INTO modxji_session (id, access, data) VALUES ('61a6777f592d53fe3337e8cfcf05ec80a', 1566966724, 'modx.user.0.resourceGroups|a:1:1:{s:3:"web";a:1:0;s:1:"6";}}modx.user "6";}}modx.user..attributes|a:2:{s:3:"mgr";a:5:{s:16:"modAccessContext";a:1:{s:3:"web";a:1:{i:0;a:3:{s:9:"principal";i:0;s:9:"authority";s:1:"0";s:6:"policy";a:1:{s:4:"load";b:1;}}}}s:22:"modAccessResourceGroup";a:0:{s:17:

    • здесь куча символов *

    Array
    (
    [0] => HY000
    [1] => 2006
    [2] => MySQL server has gone away
    )
    Вылет случился из-за I/O(резко повысился до 2 мб) и крашнулось все.

    Подскажите пожалуйста глупому, это ошибка моя или со стороны хостинга?

    написал в MODX - Вопросы и обсуждения Читать далее
  • Y
    Yiliy

    Отключил log_deprecated и в логе осталась только ошибка кэша(PHP warning: Illegal string offset 'cls')
    Значит ошибка на стороне сервера и нужно .htaccess откредактировать?

    написал в MODX - Вопросы и обсуждения Читать далее
  • Y
    Yiliy

    На сайте установлен MODX 2.7.1
    Окей, сейчас отключу

    написал в MODX - Вопросы и обсуждения Читать далее
  • Y
    Yiliy

    [2019-08-21 15:01:45] (ERROR in modProcessor::run @/путь к сайту/core/model/modx/modprocessor.class.php : 177) Flat file processor support, used for action import with path /путь к сайту/core/components/catalogfill/processors/mgr/import.php, is deprecated since version 2.7.0. - В логах
    Что это может значить?

    написал в MODX - Вопросы и обсуждения Читать далее
  • Y
    Yiliy

    Если понадобится, могу разделить по 200-300 мб, но чем больше размер(и меньше файлов) тем лучше.
    Что бы по пол часа не сидеть импортируя в каждый каталог.
    Кстати, в файлах идут все данные товаров в перемешку(в 1 файле есть данные ,к примеру, товаров которые в 11\13 и 23 каталогах а в 2 есть данные о 11\ 18 и 20 и т.д. - Всего каталогов 15, если бы было меньше вручную сделал бы разделив на маленькие куски, но я попробовал 50 мб импортировать и там тоже выпала error -1, так что задал вопрос здесь =( )

    написал в MODX - Вопросы и обсуждения Читать далее