Перейти к содержанию
Форум поддержки пользователей VamShop

Рекомендуемые сообщения

1 минуту назад, ZM сказал:

Да это понятно но они все упадут в одну категорию а хотелось бы чтобы подкатегории были но были в тестовом разделе.

Так сказать при импорте указывать куда импортировать все. А не смешивать все в одну. 

Ну это всё возможно только ручными правками файла с данными.

Либо просто создавать неактивные категории, товара.

Что б были в идны только в админке, но в каталоге не видны были товары эти.

 

Ссылка на сообщение
Поделиться на другие сайты
  • Ответов 52
  • Created
  • Последний ответ

Top Posters In This Topic

  • IVAN.Z

    28

  • support

    25

Понятно, буду надеяться что когда то появится такой код ) Спасибо. 

p.s как вывести краткое описание в карточке товара после основного описания? ) 

Ссылка на сообщение
Поделиться на другие сайты
25 минут назад, ZM сказал:

Понятно, буду надеяться что когда то появится такой код ) Спасибо. 

p.s как вывести краткое описание в карточке товара после основного описания? ) 

Какой код?!

Скрипт ведь ничего не придумывает.

Берёт файл с данными и грузит в базу VamShop.

Никаких дополнительных категорий не создаёт.

 

Не надо в одной теме разные вопросы мешать.

Ответ можно найти по PRODUCT_SHORT_DESCRITION

А лучше создать отдельную тему.

Ссылка на сообщение
Поделиться на другие сайты

Вопрос, в файле поставщика есть несколько <picture> для одного товара, но записывается только 1, сколько будет стоить допилить нынешний скрипт чтобы он дописывал остальные картинки в таблицу? (базу)

Ссылка на сообщение
Поделиться на другие сайты
1 час назад, ZM сказал:

Вопрос, в файле поставщика есть несколько <picture> для одного товара, но записывается только 1, сколько будет стоить допилить нынешний скрипт чтобы он дописывал остальные картинки в таблицу? (базу)

Добавил импорт всех картинок.

Файл прицепил /admin/yml_import.php

P.S. Будет стоить 500 руб.

 

yml_import.php

Ссылка на сообщение
Поделиться на другие сайты

Я пока скачивать не буду в плане оплаты надо еще обсудить с дир... ну если че из своей зп заплачу если дальше будем работать с этим поставщиком. 

Вот вы быстрые ) 

Ссылка на сообщение
Поделиться на другие сайты

И можно будет что-то с символами сделать которые при импорте выпали в строчки EOREOR ? 

В файле наверно есть строчки которые не читаются движком или их вычислить и сделать автоматическую замену, просто может задеть и другие строки и товары.

При доб файла может товар и залился на сайте но после выгрузки в EXCEL он показал 600+ строк с EOREOR

Ссылка на сообщение
Поделиться на другие сайты
Только что, ZM сказал:

И можно будет что-то с символами сделать которые при импорте выпали в строчки EOREOR ? 

В файле наверно есть строчки которые не читаются движком или их вычислить и сделать автоматическую замену, просто может задеть и другие строки и товары.

EOREOR - это обозначает конец сттроки в Админке - Разное - Excel импорт/экспорт.

Причём здесь yml_import!?

Не надо разные вопросы мешать в одной теме.

Ссылка на сообщение
Поделиться на другие сайты

Кстати в самом файле я сменил product_model с Артикула на uuid т.к по артиклу они повторяются и правильнее будет доб по этому uuid чтобы весь товар добавился... 

 

Только вот не пойму как vendor прицепить уходит в ошибку а она не записывается почему то... 

Смог только записывать вендор в шорт дискрипт а надо чтобы создавалось manufacture но там видимо по другому все устроено...

<?php
/* --------------------------------------------------------------
   $Id: yml_import.php,v 1.1 2010-08-06 17:36:57 VaM $

   VaM Shop - open source ecommerce solution
   http://vamshop.ru
   http://vamshop.com

   Copyright (c) 2010 VaMSoft Ltd.
   --------------------------------------------------------------
   Released under the GNU General Public License
   --------------------------------------------------------------*/
   
function unhtmlentities($string) {
  $trans_tbl = get_html_translation_table(HTML_ENTITIES);
  $trans_tbl = array_flip ($trans_tbl);
  return strtr ($string, $trans_tbl);
}

require('includes/application_top.php');

if ($_POST['action']=='import') {
  if (is_uploaded_file($_FILES['xml_file']['tmp_name'])) {


$xml = simplexml_load_file($_FILES['xml_file']['tmp_name']);

    $count=0;
    $count_upd=0;
    $count_add=0;
    $count_cat_upd=0;
    $count_cat_add=0;
    
    // Categories import
    
    foreach ($xml->shop->categories->category as $category) {

      $categories_id = $category['id'];
      $parent_id = ((!isset($category['parentId'])) ? 0 : $category['parentId']);
      $categories_name = unhtmlentities($category);
      $categories_description = '';

      $categories_query = vam_db_query("select categories_name from " . TABLE_CATEGORIES_DESCRIPTION . " where categories_id = '" . $categories_id . "' and language_id = '".$_SESSION['languages_id']."' limit 1");
      if (vam_db_num_rows($categories_query)) {
        $row=vam_db_fetch_array($categories_query);
        if ($row['categories_name']!=$categories_name) {
          vam_db_perform(TABLE_CATEGORIES, array('last_modified' => 'now()', 'parent_id' => $parent_id, 'categories_status' => 1, 'group_permission_0' => 1, 'group_permission_1' => 1, 'group_permission_2' => 1, 'group_permission_3' => 1, 'date_added' => 'now()'), 'update', 'categories_id=\''.$categories_id.'\'');
          vam_db_perform(TABLE_CATEGORIES_DESCRIPTION, array('categories_name' => $categories_name, 'categories_description' => $categories_description), 'update', 'categories_id=\''.$categories_id.'\' and language_id=\''.$_SESSION['languages_id'].'\'');
          $count_cat_upd++;
        }
      } else {
          vam_db_perform(TABLE_CATEGORIES, array('categories_id' => $categories_id, 'last_modified' => 'now()', 'parent_id' => $parent_id, 'categories_status' => 1, 'group_permission_0' => 1, 'group_permission_1' => 1, 'group_permission_2' => 1, 'group_permission_3' => 1, 'date_added' => 'now()'));
          vam_db_perform(TABLE_CATEGORIES_DESCRIPTION, array('categories_id' => $categories_id, 'categories_name' => $categories_name, 'categories_description' => $categories_description));
        $count_cat_add++;
      }
      
    }
        
    // Products import

    foreach ($xml->shop->offers->offer as $product) {
    	
      $products_id = $product['id'];
      $products_stock = (($product['available']) ? 0 : 10000);
      
      foreach ($product->param as $params) {
      if ($params['name'] == "uuid") {
    	  $products_model = (($params['name'] == "uuid") ? $params : $products_id);
      }
      if ($params['name'] == "Цена РРЦ") {
    	  $products_price = (($params['name'] == "Цена РРЦ") ? $params : $product->price);
      }
      if ($params['name'] == "Количество") {
    	  $products_quantity = (($params['name'] == "Количество") ? $params : $products_stock);
      }
      }
      
      $categoryId = $product->categoryId;
      $products_image = substr(strrchr($product->picture, "/"), 1);
      $products_name = unhtmlentities($product->name);
      $products_description = unhtmlentities($product->description);
      $products_short_description = unhtmlentities($product->vendor);
      $products_status = 1;

      $products_query = vam_db_query("select products_id, products_price from " . TABLE_PRODUCTS . " where products_id = '" . $products_id . "' limit 1");
      if (vam_db_num_rows($products_query)) {
        $row=vam_db_fetch_array($products_query);
        if ($row['products_price']!=$products_price) {
          vam_db_perform(TABLE_PRODUCTS, array(
          'products_last_modified' => 'now()', 
          'products_price' => $products_price, 
          'products_image' => $products_image, 
          'group_permission_0' => 1, 
          'group_permission_1' => 1, 
          'group_permission_2' => 1, 
          'group_permission_3' => 1, 
          'products_startpage' => 1, 
          'products_status' => $products_status, 
          'products_quantity' => $products_quantity, 
          'products_model' => $products_model, 
          'products_date_available' => 'now()'), 
          'update', 'products_id=\''.$products_id.'\'');
          vam_db_perform(TABLE_PRODUCTS_DESCRIPTION, array(
          'products_name' => $products_name, 
          'products_short_description' => $products_short_description, 	  
          'products_description' => $products_description), 
          'update', 'products_id=\''.$products_id.'\' and language_id=\''.$_SESSION['languages_id'].'\'');
          $count_upd++;
        }
      } else {
        vam_db_perform(TABLE_PRODUCTS, array(
        'products_id' => $products_id, 
        'products_last_modified' => 'now()', 
        'products_price' => $products_price, 
        'products_image' => $products_image, 
        'group_permission_0' => 1, 
        'group_permission_1' => 1, 
        'group_permission_2' => 1, 
        'group_permission_3' => 1, 
        'products_startpage' => 1, 
        'products_status' => $products_status, 
        'products_quantity' => $products_quantity, 
        'products_model' => $products_model, 
        'products_date_available' => 'now()')
        );
        vam_db_perform(TABLE_PRODUCTS_DESCRIPTION, array(
        'products_id' => $products_id, 
        'products_name' => $products_name, 
        'products_short_description' => $products_short_description,	
        'products_description' => $products_description, 
        'language_id' => $_SESSION['languages_id'])
        );
        vam_db_perform(TABLE_PRODUCTS_TO_CATEGORIES, array(
        'products_id' => $products_id, 
        'categories_id' => $categoryId)
        );
        $count_add++;
      }
      $count++;
    }

    $messageStack->add_session(TEXT_YML_UPDATED.$count_upd, 'success');
    $messageStack->add_session(TEXT_YML_CHANGED.($count-$count_upd), 'success');
    $messageStack->add_session(TEXT_YML_ADDED.$count_add, 'success');
    $messageStack->add_session(TEXT_YML_CAT_ADDED.$count_cat_add, 'success');
    $messageStack->add_session(TEXT_YML_CAT_UPDATED.$count_cat_upd, 'success');
  } else {
    $messageStack->add_session(TEXT_YML_ERROR, 'error');
  }

  vam_redirect(vam_href_link(FILENAME_YML_IMPORT));
}

?>
<!DOCTYPE html>
<html <?php echo HTML_PARAMS; ?>>
<head>
<!--<meta name="viewport" content="initial-scale=1.0, width=device-width" />-->
<meta http-equiv="Content-Type" content="text/html; charset=<?php echo $_SESSION['language_charset']; ?>"> 
<title><?php echo TITLE; ?></title>
<!-- Header JS, CSS -->
<?php require(DIR_FS_ADMIN.DIR_WS_INCLUDES . 'header_include.php'); ?>
</head>
<body marginwidth="0" marginheight="0" topmargin="0" bottommargin="0" leftmargin="0" rightmargin="0" bgcolor="#FFFFFF">
<!-- header //-->
<?php require(DIR_WS_INCLUDES . 'header.php'); ?>
<!-- header_eof //-->

<!-- body //-->
<table border="0" width="100%" cellspacing="2" cellpadding="2">
  <tr>
<?php if (ADMIN_DROP_DOWN_NAVIGATION == 'false') { ?>
    <td width="<?php echo BOX_WIDTH; ?>" align="left" valign="top">
<!-- left_navigation //-->
<?php require(DIR_WS_INCLUDES . 'column_left.php'); ?>
<!-- left_navigation_eof //-->
    </td>
<?php } ?>
<!-- body_text //-->
    <td class="boxCenter" valign="top"><table border="0" width="100%" cellspacing="0" cellpadding="2">
      <tr>
        <td class="main">
        
    <h1 class="contentBoxHeading"><?php echo HEADING_TITLE; ?></h1>
            
        <table border="0" width="100%" cellspacing="0" cellpadding="0">
         
          <tr>
        <td class="main">
          <?php echo vam_draw_form('xml_import', FILENAME_YML_IMPORT, '', 'post', 'enctype="multipart/form-data"') ."\n". vam_draw_file_field('xml_file') ."\n"; ?>
          <input type="hidden" name="action" value="import">
          <br>
          <?php echo TEXT_YML_MAX_SIZE; ?> <b><?php echo ini_get('upload_max_filesize'); ?></b><br />
          <span class="button"><button type="submit" value="<?php echo TEXT_YML_IMPORT; ?>"><?php echo vam_image(DIR_WS_IMAGES . 'icons/buttons/import.png', '', '12', '12'); ?>&nbsp;<?php echo TEXT_YML_IMPORT; ?></button>
          </form>
        </td>
        <td class="main" width="50%" valign="bottom">
          <a class="button" href="<?php echo HTTP_SERVER . DIR_WS_CATALOG.'market.php'; ?>" target="_blank"><span><?php echo vam_image(DIR_WS_IMAGES . 'icons/buttons/export.png', '', '12', '12'); ?>&nbsp;<?php echo TEXT_YML_EXPORT; ?></span></a>
        </td>
      </tr>
    </table></td>
<!-- body_text_eof //-->
  </tr>
</table>
<!-- body_eof //-->

<!-- footer //-->
<?php require(DIR_WS_INCLUDES . 'footer.php'); ?>
<!-- footer_eof //-->
<br>
</body>
</html>
<?php require(DIR_WS_INCLUDES . 'application_bottom.php'); ?>

 

Похоже нужно делать переход в manufacturers по этому типу и записывать значения vendor

vam_db_perform(TABLE_PRODUCTS_DESCRIPTION, array(

Ссылка на сообщение
Поделиться на другие сайты

=================================

upd v1.0

Допилено date_added 

=================================

<?php
/* --------------------------------------------------------------
   $Id: yml_import.php,v 1.1 2010-08-06 17:36:57 VaM $

   VaM Shop - open source ecommerce solution
   http://vamshop.ru
   http://vamshop.com

   Copyright (c) 2010 VaMSoft Ltd.
   --------------------------------------------------------------
   Released under the GNU General Public License
   --------------------------------------------------------------*/
   
function unhtmlentities($string) {
  $trans_tbl = get_html_translation_table(HTML_ENTITIES);
  $trans_tbl = array_flip ($trans_tbl);
  return strtr ($string, $trans_tbl);
}

require('includes/application_top.php');

if ($_POST['action']=='import') {
  if (is_uploaded_file($_FILES['xml_file']['tmp_name'])) {


$xml = simplexml_load_file($_FILES['xml_file']['tmp_name']);

    $count=0;
    $count_upd=0;
    $count_add=0;
    $count_cat_upd=0;
    $count_cat_add=0;
    
    // Categories import
    
    foreach ($xml->shop->categories->category as $category) {

      $categories_id = $category['id'];
      $parent_id = ((!isset($category['parentId'])) ? 0 : $category['parentId']);
      $categories_name = unhtmlentities($category);
      $categories_description = '';

      $categories_query = vam_db_query("select categories_name from " . TABLE_CATEGORIES_DESCRIPTION . " where categories_id = '" . $categories_id . "' and language_id = '".$_SESSION['languages_id']."' limit 1");
      if (vam_db_num_rows($categories_query)) {
        $row=vam_db_fetch_array($categories_query);
        if ($row['categories_name']!=$categories_name) {
          vam_db_perform(TABLE_CATEGORIES, array('last_modified' => 'now()', 'parent_id' => $parent_id, 'categories_status' => 1, 'group_permission_0' => 1, 'group_permission_1' => 1, 'group_permission_2' => 1, 'group_permission_3' => 1, 'date_added' => 'now()'), 'update', 'categories_id=\''.$categories_id.'\'');
          vam_db_perform(TABLE_CATEGORIES_DESCRIPTION, array('categories_name' => $categories_name, 'categories_description' => $categories_description), 'update', 'categories_id=\''.$categories_id.'\' and language_id=\''.$_SESSION['languages_id'].'\'');
          $count_cat_upd++;
        }
      } else {
          vam_db_perform(TABLE_CATEGORIES, array('categories_id' => $categories_id, 'last_modified' => 'now()', 'parent_id' => $parent_id, 'categories_status' => 1, 'group_permission_0' => 1, 'group_permission_1' => 1, 'group_permission_2' => 1, 'group_permission_3' => 1, 'date_added' => 'now()'));
          vam_db_perform(TABLE_CATEGORIES_DESCRIPTION, array('categories_id' => $categories_id, 'categories_name' => $categories_name, 'categories_description' => $categories_description));
        $count_cat_add++;
      }
      
    }
        
    // Products import

    foreach ($xml->shop->offers->offer as $product) {
    	
      $products_id = $product['id'];
      $products_stock = (($product['available']) ? 0 : 10000);
      
      foreach ($product->param as $params) {
      if ($params['name'] == "uuid") {
    	  $products_model = (($params['name'] == "uuid") ? $params : $products_id);
      }
      if ($params['name'] == "Цена РРЦ") {
    	  $products_price = (($params['name'] == "Цена РРЦ") ? $params : $product->price);
      }
      if ($params['name'] == "Количество") {
    	  $products_quantity = (($params['name'] == "Количество") ? $params : $products_stock);
      }
      }
      
      $categoryId = $product->categoryId;
      $products_image = substr(strrchr($product->picture, "/"), 1);
      $products_name = unhtmlentities($product->name);
      $products_description = unhtmlentities($product->description);
      $products_short_description = unhtmlentities($product->vendor);
      $products_status = 1;

      $products_query = vam_db_query("select products_id, products_price from " . TABLE_PRODUCTS . " where products_id = '" . $products_id . "' limit 1");
      if (vam_db_num_rows($products_query)) {
        $row=vam_db_fetch_array($products_query);
        if ($row['products_price']!=$products_price) {
          vam_db_perform(TABLE_PRODUCTS, array(
          'products_last_modified' => 'now()',
          'products_date_added' => 'now()',	   
          'products_price' => $products_price, 
          'products_image' => $products_image, 
          'group_permission_0' => 1, 
          'group_permission_1' => 1, 
          'group_permission_2' => 1, 
          'group_permission_3' => 1, 
          'products_startpage' => 1, 
          'products_status' => $products_status, 
          'products_quantity' => $products_quantity, 
          'products_model' => $products_model, 
          'products_date_available' => 'now()'), 
          'update', 'products_id=\''.$products_id.'\'');
          vam_db_perform(TABLE_PRODUCTS_DESCRIPTION, array(
          'products_name' => $products_name, 
          'products_short_description' => $products_short_description, 	  
          'products_description' => $products_description), 
          'update', 'products_id=\''.$products_id.'\' and language_id=\''.$_SESSION['languages_id'].'\'');
          $count_upd++;
        }
      } else {
        vam_db_perform(TABLE_PRODUCTS, array(
        'products_id' => $products_id,
        'products_date_added' => 'now()',	 
        'products_last_modified' => 'now()', 
        'products_price' => $products_price, 
        'products_image' => $products_image, 
        'group_permission_0' => 1, 
        'group_permission_1' => 1, 
        'group_permission_2' => 1, 
        'group_permission_3' => 1, 
        'products_startpage' => 1, 
        'products_status' => $products_status, 
        'products_quantity' => $products_quantity, 
        'products_model' => $products_model, 
        'products_date_available' => 'now()')
        );
        vam_db_perform(TABLE_PRODUCTS_DESCRIPTION, array(
        'products_id' => $products_id, 
        'products_name' => $products_name,
        'products_short_description' => $products_short_description,	 
        'products_description' => $products_description, 
        'language_id' => $_SESSION['languages_id'])
        );
        vam_db_perform(TABLE_PRODUCTS_TO_CATEGORIES, array(
        'products_id' => $products_id, 
        'categories_id' => $categoryId)
        );
        $count_add++;
      }
      $count++;
    }

    $messageStack->add_session(TEXT_YML_UPDATED.$count_upd, 'success');
    $messageStack->add_session(TEXT_YML_CHANGED.($count-$count_upd), 'success');
    $messageStack->add_session(TEXT_YML_ADDED.$count_add, 'success');
    $messageStack->add_session(TEXT_YML_CAT_ADDED.$count_cat_add, 'success');
    $messageStack->add_session(TEXT_YML_CAT_UPDATED.$count_cat_upd, 'success');
  } else {
    $messageStack->add_session(TEXT_YML_ERROR, 'error');
  }

  vam_redirect(vam_href_link(FILENAME_YML_IMPORT));
}

?>
<!DOCTYPE html>
<html <?php echo HTML_PARAMS; ?>>
<head>
<!--<meta name="viewport" content="initial-scale=1.0, width=device-width" />-->
<meta http-equiv="Content-Type" content="text/html; charset=<?php echo $_SESSION['language_charset']; ?>"> 
<title><?php echo TITLE; ?></title>
<!-- Header JS, CSS -->
<?php require(DIR_FS_ADMIN.DIR_WS_INCLUDES . 'header_include.php'); ?>
</head>
<body marginwidth="0" marginheight="0" topmargin="0" bottommargin="0" leftmargin="0" rightmargin="0" bgcolor="#FFFFFF">
<!-- header //-->
<?php require(DIR_WS_INCLUDES . 'header.php'); ?>
<!-- header_eof //-->

<!-- body //-->
<table border="0" width="100%" cellspacing="2" cellpadding="2">
  <tr>
<?php if (ADMIN_DROP_DOWN_NAVIGATION == 'false') { ?>
    <td width="<?php echo BOX_WIDTH; ?>" align="left" valign="top">
<!-- left_navigation //-->
<?php require(DIR_WS_INCLUDES . 'column_left.php'); ?>
<!-- left_navigation_eof //-->
    </td>
<?php } ?>
<!-- body_text //-->
    <td class="boxCenter" valign="top"><table border="0" width="100%" cellspacing="0" cellpadding="2">
      <tr>
        <td class="main">
        
    <h1 class="contentBoxHeading"><?php echo HEADING_TITLE; ?></h1>
            
        <table border="0" width="100%" cellspacing="0" cellpadding="0">
         
          <tr>
        <td class="main">
          <?php echo vam_draw_form('xml_import', FILENAME_YML_IMPORT, '', 'post', 'enctype="multipart/form-data"') ."\n". vam_draw_file_field('xml_file') ."\n"; ?>
          <input type="hidden" name="action" value="import">
          <br>
          <?php echo TEXT_YML_MAX_SIZE; ?> <b><?php echo ini_get('upload_max_filesize'); ?></b><br />
          <span class="button"><button type="submit" value="<?php echo TEXT_YML_IMPORT; ?>"><?php echo vam_image(DIR_WS_IMAGES . 'icons/buttons/import.png', '', '12', '12'); ?>&nbsp;<?php echo TEXT_YML_IMPORT; ?></button>
          </form>
        </td>
        <td class="main" width="50%" valign="bottom">
          <a class="button" href="<?php echo HTTP_SERVER . DIR_WS_CATALOG.'market.php'; ?>" target="_blank"><span><?php echo vam_image(DIR_WS_IMAGES . 'icons/buttons/export.png', '', '12', '12'); ?>&nbsp;<?php echo TEXT_YML_EXPORT; ?></span></a>
        </td>
      </tr>
    </table></td>
<!-- body_text_eof //-->
  </tr>
</table>
<!-- body_eof //-->

<!-- footer //-->
<?php require(DIR_WS_INCLUDES . 'footer.php'); ?>
<!-- footer_eof //-->
<br>
</body>
</html>
<?php require(DIR_WS_INCLUDES . 'application_bottom.php'); ?>

 

Ссылка на сообщение
Поделиться на другие сайты

vendor - это производитель.

Его надо записать в таблицы manufacturers, manufacturers_info

и затем уже самому товару добавлять в колонке manufacturers_id в таблице products

Так просто импорт производителей не сделать, указав просто ->vendor

Ссылка на сообщение
Поделиться на другие сайты

===========

upd v 1.1

===========

Добавляет название для картинок из имени товара.

Товар на главную страницу в виде параметра 0 ( чтобы не засорять основу витрины )

<?php
/* --------------------------------------------------------------
   $Id: yml_import.php,v 1.1 2010-08-06 17:36:57 VaM $

   VaM Shop - open source ecommerce solution
   http://vamshop.ru
   http://vamshop.com

   Copyright (c) 2010 VaMSoft Ltd.
   --------------------------------------------------------------
   Released under the GNU General Public License
   --------------------------------------------------------------*/
   
function unhtmlentities($string) {
  $trans_tbl = get_html_translation_table(HTML_ENTITIES);
  $trans_tbl = array_flip ($trans_tbl);
  return strtr ($string, $trans_tbl);
}

require('includes/application_top.php');

if ($_POST['action']=='import') {
  if (is_uploaded_file($_FILES['xml_file']['tmp_name'])) {


$xml = simplexml_load_file($_FILES['xml_file']['tmp_name']);

    $count=0;
    $count_upd=0;
    $count_add=0;
    $count_cat_upd=0;
    $count_cat_add=0;
    
    // Categories import
    
    foreach ($xml->shop->categories->category as $category) {

      $categories_id = $category['id'];
      $parent_id = ((!isset($category['parentId'])) ? 0 : $category['parentId']);
      $categories_name = unhtmlentities($category);
      $categories_description = '';

      $categories_query = vam_db_query("select categories_name from " . TABLE_CATEGORIES_DESCRIPTION . " where categories_id = '" . $categories_id . "' and language_id = '".$_SESSION['languages_id']."' limit 1");
      if (vam_db_num_rows($categories_query)) {
        $row=vam_db_fetch_array($categories_query);
        if ($row['categories_name']!=$categories_name) {
          vam_db_perform(TABLE_CATEGORIES, array('last_modified' => 'now()', 'parent_id' => $parent_id, 'categories_status' => 1, 'group_permission_0' => 1, 'group_permission_1' => 1, 'group_permission_2' => 1, 'group_permission_3' => 1, 'date_added' => 'now()'), 'update', 'categories_id=\''.$categories_id.'\'');
          vam_db_perform(TABLE_CATEGORIES_DESCRIPTION, array('categories_name' => $categories_name, 'categories_description' => $categories_description), 'update', 'categories_id=\''.$categories_id.'\' and language_id=\''.$_SESSION['languages_id'].'\'');
          $count_cat_upd++;
        }
      } else {
          vam_db_perform(TABLE_CATEGORIES, array('categories_id' => $categories_id, 'last_modified' => 'now()', 'parent_id' => $parent_id, 'categories_status' => 1, 'group_permission_0' => 1, 'group_permission_1' => 1, 'group_permission_2' => 1, 'group_permission_3' => 1, 'date_added' => 'now()'));
          vam_db_perform(TABLE_CATEGORIES_DESCRIPTION, array('categories_id' => $categories_id, 'categories_name' => $categories_name, 'categories_description' => $categories_description));
        $count_cat_add++;
      }
      
    }
        
    // Products import

    foreach ($xml->shop->offers->offer as $product) {
    	
      $products_id = $product['id'];
      $products_stock = (($product['available']) ? 0 : 10000);
      
      foreach ($product->param as $params) {
      if ($params['name'] == "uuid") {
    	  $products_model = (($params['name'] == "uuid") ? $params : $products_id);
      }
      if ($params['name'] == "Цена РРЦ") {
    	  $products_price = (($params['name'] == "Цена РРЦ") ? $params : $product->price);
      }
      if ($params['name'] == "Количество") {
    	  $products_quantity = (($params['name'] == "Количество") ? $params : $products_stock);
      }
      }
      
      $categoryId = $product->categoryId;
      $products_image = substr(strrchr($product->picture, "/"), 1);
      $products_name = unhtmlentities($product->name);
      $products_image_description = unhtmlentities($product->name);
      $products_description = $product->description;
      $products_short_description = unhtmlentities($product->vendor);
      $products_status = 1;

      $products_query = vam_db_query("select products_id, products_price from " . TABLE_PRODUCTS . " where products_id = '" . $products_id . "' limit 1");
      if (vam_db_num_rows($products_query)) {
        $row=vam_db_fetch_array($products_query);
        if ($row['products_price']!=$products_price) {
          vam_db_perform(TABLE_PRODUCTS, array(
          'products_last_modified' => 'now()',
          'products_date_added' => 'now()',	   
          'products_price' => $products_price, 
          'products_image' => $products_image, 
          'group_permission_0' => 1, 
          'group_permission_1' => 1, 
          'group_permission_2' => 1, 
          'group_permission_3' => 1, 
          'products_startpage' => 0, 
          'products_status' => $products_status,
          'products_image_description' => $products_name, 
          'products_quantity' => $products_quantity, 
          'products_model' => $products_model, 
          'products_date_available' => 'now()'), 
          'update', 'products_id=\''.$products_id.'\'');
          vam_db_perform(TABLE_PRODUCTS_DESCRIPTION, array(
          'products_name' => $products_name, 
          'products_short_description' => $products_short_description, 	  
          'products_description' => $products_description), 
          'update', 'products_id=\''.$products_id.'\' and language_id=\''.$_SESSION['languages_id'].'\'');
          $count_upd++;
        }
      } else {
        vam_db_perform(TABLE_PRODUCTS, array(
        'products_id' => $products_id,
        'products_date_added' => 'now()',	 
        'products_last_modified' => 'now()', 
        'products_price' => $products_price, 
        'products_image' => $products_image, 
        'group_permission_0' => 1, 
        'group_permission_1' => 1, 
        'group_permission_2' => 1, 
        'group_permission_3' => 1, 
        'products_startpage' => 0, 
        'products_status' => $products_status,
        'products_image_description' => $products_name, 
        'products_quantity' => $products_quantity, 
        'products_model' => $products_model, 
        'products_date_available' => 'now()')
        );
        vam_db_perform(TABLE_PRODUCTS_DESCRIPTION, array(
        'products_id' => $products_id, 
        'products_name' => $products_name,
        'products_short_description' => $products_short_description,	 
        'products_description' => $products_description, 
        'language_id' => $_SESSION['languages_id'])
        );
        vam_db_perform(TABLE_PRODUCTS_TO_CATEGORIES, array(
        'products_id' => $products_id, 
        'categories_id' => $categoryId)
        );
        $count_add++;
      }
      $count++;
    }

    $messageStack->add_session(TEXT_YML_UPDATED.$count_upd, 'success');
    $messageStack->add_session(TEXT_YML_CHANGED.($count-$count_upd), 'success');
    $messageStack->add_session(TEXT_YML_ADDED.$count_add, 'success');
    $messageStack->add_session(TEXT_YML_CAT_ADDED.$count_cat_add, 'success');
    $messageStack->add_session(TEXT_YML_CAT_UPDATED.$count_cat_upd, 'success');
  } else {
    $messageStack->add_session(TEXT_YML_ERROR, 'error');
  }

  vam_redirect(vam_href_link(FILENAME_YML_IMPORT));
}

?>
<!DOCTYPE html>
<html <?php echo HTML_PARAMS; ?>>
<head>
<!--<meta name="viewport" content="initial-scale=1.0, width=device-width" />-->
<meta http-equiv="Content-Type" content="text/html; charset=<?php echo $_SESSION['language_charset']; ?>"> 
<title><?php echo TITLE; ?></title>
<!-- Header JS, CSS -->
<?php require(DIR_FS_ADMIN.DIR_WS_INCLUDES . 'header_include.php'); ?>
</head>
<body marginwidth="0" marginheight="0" topmargin="0" bottommargin="0" leftmargin="0" rightmargin="0" bgcolor="#FFFFFF">
<!-- header //-->
<?php require(DIR_WS_INCLUDES . 'header.php'); ?>
<!-- header_eof //-->

<!-- body //-->
<table border="0" width="100%" cellspacing="2" cellpadding="2">
  <tr>
<?php if (ADMIN_DROP_DOWN_NAVIGATION == 'false') { ?>
    <td width="<?php echo BOX_WIDTH; ?>" align="left" valign="top">
<!-- left_navigation //-->
<?php require(DIR_WS_INCLUDES . 'column_left.php'); ?>
<!-- left_navigation_eof //-->
    </td>
<?php } ?>
<!-- body_text //-->
    <td class="boxCenter" valign="top"><table border="0" width="100%" cellspacing="0" cellpadding="2">
      <tr>
        <td class="main">
        
    <h1 class="contentBoxHeading"><?php echo HEADING_TITLE; ?></h1>
            
        <table border="0" width="100%" cellspacing="0" cellpadding="0">
         
          <tr>
        <td class="main">
          <?php echo vam_draw_form('xml_import', FILENAME_YML_IMPORT, '', 'post', 'enctype="multipart/form-data"') ."\n". vam_draw_file_field('xml_file') ."\n"; ?>
          <input type="hidden" name="action" value="import">
          <br>
          <?php echo TEXT_YML_MAX_SIZE; ?> <b><?php echo ini_get('upload_max_filesize'); ?></b><br />
          <span class="button"><button type="submit" value="<?php echo TEXT_YML_IMPORT; ?>"><?php echo vam_image(DIR_WS_IMAGES . 'icons/buttons/import.png', '', '12', '12'); ?>&nbsp;<?php echo TEXT_YML_IMPORT; ?></button>
          </form>
        </td>
        <td class="main" width="50%" valign="bottom">
          <a class="button" href="<?php echo HTTP_SERVER . DIR_WS_CATALOG.'market.php'; ?>" target="_blank"><span><?php echo vam_image(DIR_WS_IMAGES . 'icons/buttons/export.png', '', '12', '12'); ?>&nbsp;<?php echo TEXT_YML_EXPORT; ?></span></a>
        </td>
      </tr>
    </table></td>
<!-- body_text_eof //-->
  </tr>
</table>
<!-- body_eof //-->

<!-- footer //-->
<?php require(DIR_WS_INCLUDES . 'footer.php'); ?>
<!-- footer_eof //-->
<br>
</body>
</html>
<?php require(DIR_WS_INCLUDES . 'application_bottom.php'); ?>

p.s надеюсь не против что тут небольшой changelog веду...

Ссылка на сообщение
Поделиться на другие сайты

И зачем так делать?!

В файле yml уже есть ведь картинки, готовые, адрес картинки.

Достаточно лишь выкачать их и всё.

Хотя Вам виднее, делайте как считаете нужным.

Ссылка на сообщение
Поделиться на другие сайты
1 час назад, ZM сказал:

Так это атрибут alt для картинки ведь вроде? Он разве не нужен к картине? 

Причём здесь атрибут alt?

Картинки как доставать будете из yml и переписывать в магазин?!

Ссылка на сообщение
Поделиться на другие сайты

Легко, скормив его Download Master, а yml_import и так прописывает картинку товару, пока только одну хоть вы и дали другой файл но пока возможности оплатить нету

Ссылка на сообщение
Поделиться на другие сайты
2 часа назад, ZM сказал:

Легко, скормив его Download Master, а yml_import и так прописывает картинку товару, пока только одну хоть вы и дали другой файл но пока возможности оплатить нету

Понятно.

alt и так подставляется в виде названия товара.

 

Ссылка на сообщение
Поделиться на другие сайты
6 минут назад, ZM сказал:

А зачем тогда поле описание для картинки в админке? 

Затем что б уникализировать описание картинки.

У Вас в yml данных всё равно нет текста который можно было бы добавить в alt.

 

Ссылка на сообщение
Поделиться на другие сайты
В 22.05.2020 в 13:20, ZM сказал:

Да это понятно но они все упадут в одну категорию а хотелось бы чтобы подкатегории были но были в тестовом разделе.

Так сказать при импорте указывать куда импортировать все. А не смешивать все в одну. 

Если всё понятно, то просто сделайте как Вам надо.

Код открыт.

Структура YML у Вас другая.

Раз надо в какие-то свои категории, то это только через правку импорта.

Менять категории, что указаны в YML файлы, на свои.

Ссылка на сообщение
Поделиться на другие сайты

Это нереально, менять id категорий и ID товаров, я сначала выгружаю на тестовый сайт, потом создаю категорию и переношу туда товар, а потом экспортом выгружаю это дело в EXCEL CVS но при этом не выгружаются не читаемые символы, после чего доб данных если надо и загружаю обратно.

А может попробывать через YML экспорт а потом в основную базу через YML импорт чтобы решить проблему с символами..

Ссылка на сообщение
Поделиться на другие сайты
В 22.05.2020 в 13:20, ZM сказал:

Да это понятно но они все упадут в одну категорию а хотелось бы чтобы подкатегории были но были в тестовом разделе.

Так сказать при импорте указывать куда импортировать все. А не смешивать все в одну. 

Я ещё раз говорю, всё это делается правками кода.

Просто в yml_import добавляйте новую основную категорию, кодом.

А всё, что приходит их прайса, делаете что б добавлялось в эту Ваше основновную категорию.

Хотя если всё это разово делается, проще вообще в админке перекинуть все сразу категории с товарами во вновь созданную категорию, в админке переносить категории с товарами можно ведь быстро, просто отмечая категории.

Ссылка на сообщение
Поделиться на другие сайты

×
×
  • Создать...