support 447 Опубликовано 22 мая, 2020 Жалоба Share Опубликовано 22 мая, 2020 1 минуту назад, ZM сказал: Да это понятно но они все упадут в одну категорию а хотелось бы чтобы подкатегории были но были в тестовом разделе. Так сказать при импорте указывать куда импортировать все. А не смешивать все в одну. Ну это всё возможно только ручными правками файла с данными. Либо просто создавать неактивные категории, товара. Что б были в идны только в админке, но в каталоге не видны были товары эти. Ссылка на сообщение Поделиться на другие сайты
IVAN.Z 2 Опубликовано 22 мая, 2020 Автор Жалоба Share Опубликовано 22 мая, 2020 Понятно, буду надеяться что когда то появится такой код ) Спасибо. p.s как вывести краткое описание в карточке товара после основного описания? ) Ссылка на сообщение Поделиться на другие сайты
support 447 Опубликовано 22 мая, 2020 Жалоба Share Опубликовано 22 мая, 2020 25 минут назад, ZM сказал: Понятно, буду надеяться что когда то появится такой код ) Спасибо. p.s как вывести краткое описание в карточке товара после основного описания? ) Какой код?! Скрипт ведь ничего не придумывает. Берёт файл с данными и грузит в базу VamShop. Никаких дополнительных категорий не создаёт. Не надо в одной теме разные вопросы мешать. Ответ можно найти по PRODUCT_SHORT_DESCRITION А лучше создать отдельную тему. Ссылка на сообщение Поделиться на другие сайты
IVAN.Z 2 Опубликовано 29 мая, 2020 Автор Жалоба Share Опубликовано 29 мая, 2020 Вопрос, в файле поставщика есть несколько <picture> для одного товара, но записывается только 1, сколько будет стоить допилить нынешний скрипт чтобы он дописывал остальные картинки в таблицу? (базу) Ссылка на сообщение Поделиться на другие сайты
support 447 Опубликовано 29 мая, 2020 Жалоба Share Опубликовано 29 мая, 2020 1 час назад, ZM сказал: Вопрос, в файле поставщика есть несколько <picture> для одного товара, но записывается только 1, сколько будет стоить допилить нынешний скрипт чтобы он дописывал остальные картинки в таблицу? (базу) Добавил импорт всех картинок. Файл прицепил /admin/yml_import.php P.S. Будет стоить 500 руб. yml_import.php Ссылка на сообщение Поделиться на другие сайты
IVAN.Z 2 Опубликовано 29 мая, 2020 Автор Жалоба Share Опубликовано 29 мая, 2020 Я пока скачивать не буду в плане оплаты надо еще обсудить с дир... ну если че из своей зп заплачу если дальше будем работать с этим поставщиком. Вот вы быстрые ) Ссылка на сообщение Поделиться на другие сайты
support 447 Опубликовано 29 мая, 2020 Жалоба Share Опубликовано 29 мая, 2020 Ну я эту проавку в любом случае добавлю в код по умолчанию. Полезная. Ссылка на сообщение Поделиться на другие сайты
IVAN.Z 2 Опубликовано 31 мая, 2020 Автор Жалоба Share Опубликовано 31 мая, 2020 И можно будет что-то с символами сделать которые при импорте выпали в строчки EOREOR ? В файле наверно есть строчки которые не читаются движком или их вычислить и сделать автоматическую замену, просто может задеть и другие строки и товары. При доб файла может товар и залился на сайте но после выгрузки в EXCEL он показал 600+ строк с EOREOR Ссылка на сообщение Поделиться на другие сайты
support 447 Опубликовано 31 мая, 2020 Жалоба Share Опубликовано 31 мая, 2020 Только что, ZM сказал: И можно будет что-то с символами сделать которые при импорте выпали в строчки EOREOR ? В файле наверно есть строчки которые не читаются движком или их вычислить и сделать автоматическую замену, просто может задеть и другие строки и товары. EOREOR - это обозначает конец сттроки в Админке - Разное - Excel импорт/экспорт. Причём здесь yml_import!? Не надо разные вопросы мешать в одной теме. Ссылка на сообщение Поделиться на другие сайты
IVAN.Z 2 Опубликовано 31 мая, 2020 Автор Жалоба Share Опубликовано 31 мая, 2020 Ладно проще видео будет снять показать про что я имею ввиду Ссылка на сообщение Поделиться на другие сайты
IVAN.Z 2 Опубликовано 31 мая, 2020 Автор Жалоба Share Опубликовано 31 мая, 2020 Кстати в самом файле я сменил 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'); ?> <?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'); ?> <?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( Ссылка на сообщение Поделиться на другие сайты
IVAN.Z 2 Опубликовано 31 мая, 2020 Автор Жалоба Share Опубликовано 31 мая, 2020 ================================= 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'); ?> <?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'); ?> <?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'); ?> Ссылка на сообщение Поделиться на другие сайты
support 447 Опубликовано 31 мая, 2020 Жалоба Share Опубликовано 31 мая, 2020 vendor - это производитель. Его надо записать в таблицы manufacturers, manufacturers_info и затем уже самому товару добавлять в колонке manufacturers_id в таблице products Так просто импорт производителей не сделать, указав просто ->vendor Ссылка на сообщение Поделиться на другие сайты
IVAN.Z 2 Опубликовано 2 июня, 2020 Автор Жалоба Share Опубликовано 2 июня, 2020 =========== 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'); ?> <?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'); ?> <?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 веду... Ссылка на сообщение Поделиться на другие сайты
support 447 Опубликовано 2 июня, 2020 Жалоба Share Опубликовано 2 июня, 2020 И зачем так делать?! В файле yml уже есть ведь картинки, готовые, адрес картинки. Достаточно лишь выкачать их и всё. Хотя Вам виднее, делайте как считаете нужным. Ссылка на сообщение Поделиться на другие сайты
IVAN.Z 2 Опубликовано 2 июня, 2020 Автор Жалоба Share Опубликовано 2 июня, 2020 Так это атрибут alt для картинки ведь вроде? Он разве не нужен к картине? Ссылка на сообщение Поделиться на другие сайты
support 447 Опубликовано 2 июня, 2020 Жалоба Share Опубликовано 2 июня, 2020 1 час назад, ZM сказал: Так это атрибут alt для картинки ведь вроде? Он разве не нужен к картине? Причём здесь атрибут alt? Картинки как доставать будете из yml и переписывать в магазин?! Ссылка на сообщение Поделиться на другие сайты
IVAN.Z 2 Опубликовано 3 июня, 2020 Автор Жалоба Share Опубликовано 3 июня, 2020 Легко, скормив его Download Master, а yml_import и так прописывает картинку товару, пока только одну хоть вы и дали другой файл но пока возможности оплатить нету Ссылка на сообщение Поделиться на другие сайты
support 447 Опубликовано 3 июня, 2020 Жалоба Share Опубликовано 3 июня, 2020 2 часа назад, ZM сказал: Легко, скормив его Download Master, а yml_import и так прописывает картинку товару, пока только одну хоть вы и дали другой файл но пока возможности оплатить нету Понятно. alt и так подставляется в виде названия товара. Ссылка на сообщение Поделиться на другие сайты
IVAN.Z 2 Опубликовано 3 июня, 2020 Автор Жалоба Share Опубликовано 3 июня, 2020 А зачем тогда поле описание для картинки в админке? Ссылка на сообщение Поделиться на другие сайты
support 447 Опубликовано 3 июня, 2020 Жалоба Share Опубликовано 3 июня, 2020 6 минут назад, ZM сказал: А зачем тогда поле описание для картинки в админке? Затем что б уникализировать описание картинки. У Вас в yml данных всё равно нет текста который можно было бы добавить в alt. Ссылка на сообщение Поделиться на другие сайты
IVAN.Z 2 Опубликовано 3 июня, 2020 Автор Жалоба Share Опубликовано 3 июня, 2020 Ну хотя бы name - чтобы у картинок был тег alt для SEO ? Ссылка на сообщение Поделиться на другие сайты
support 447 Опубликовано 3 июня, 2020 Жалоба Share Опубликовано 3 июня, 2020 В 22.05.2020 в 13:20, ZM сказал: Да это понятно но они все упадут в одну категорию а хотелось бы чтобы подкатегории были но были в тестовом разделе. Так сказать при импорте указывать куда импортировать все. А не смешивать все в одну. Если всё понятно, то просто сделайте как Вам надо. Код открыт. Структура YML у Вас другая. Раз надо в какие-то свои категории, то это только через правку импорта. Менять категории, что указаны в YML файлы, на свои. Ссылка на сообщение Поделиться на другие сайты
IVAN.Z 2 Опубликовано 3 июня, 2020 Автор Жалоба Share Опубликовано 3 июня, 2020 Это нереально, менять id категорий и ID товаров, я сначала выгружаю на тестовый сайт, потом создаю категорию и переношу туда товар, а потом экспортом выгружаю это дело в EXCEL CVS но при этом не выгружаются не читаемые символы, после чего доб данных если надо и загружаю обратно. А может попробывать через YML экспорт а потом в основную базу через YML импорт чтобы решить проблему с символами.. Ссылка на сообщение Поделиться на другие сайты
support 447 Опубликовано 3 июня, 2020 Жалоба Share Опубликовано 3 июня, 2020 В 22.05.2020 в 13:20, ZM сказал: Да это понятно но они все упадут в одну категорию а хотелось бы чтобы подкатегории были но были в тестовом разделе. Так сказать при импорте указывать куда импортировать все. А не смешивать все в одну. Я ещё раз говорю, всё это делается правками кода. Просто в yml_import добавляйте новую основную категорию, кодом. А всё, что приходит их прайса, делаете что б добавлялось в эту Ваше основновную категорию. Хотя если всё это разово делается, проще вообще в админке перекинуть все сразу категории с товарами во вновь созданную категорию, в админке переносить категории с товарами можно ведь быстро, просто отмечая категории. Ссылка на сообщение Поделиться на другие сайты
Рекомендуемые сообщения