Заготовки для автоматического заполнения товарами магазина OpenCart 1.5.5.1.2

Вот такие данные отправляются в Модель при создании товара стандартным контроллером:

Array
(
    [product_description] => Array
        (
            [1] => Array
                (
                    [name] => Название товара
                    [seo_h1] => HTML-тег H1
                    [seo_title] => HTML-тег Title
                    [meta_keyword] => 
                    [meta_description] => 
                    [description] => 

Описание html

  • asdsa
  • afsdf
  • asdfs
[tag] => ) [2] => Array ( [name] => Название товара ENG [seo_h1] => [seo_title] => [meta_keyword] => [meta_description] => [description] => [tag] => ) ) [model] => Модель (Обязательное поле) [sku] => [upc] => [ean] => [jan] => [isbn] => [mpn] => [location] => [price] => 5800 [tax_class_id] => 0 [quantity] => 26 [minimum] => 1 [subtract] => 1 [stock_status_id] => 5 [shipping] => 1 [keyword] => here_is_seo_url [image] => data/demo/apple_cinema_30.jpg [date_available] => 2016-02-13 [length] => [width] => [height] => [length_class_id] => 1 [weight] => [weight_class_id] => 1 [status] => 1 [sort_order] => 1 [manufacturer_id] => 9 [main_category_id] => 0 [product_category] => Array ( [0] => 20 [1] => 26 ) [filter] => [product_store] => Array ( [0] => 0 ) [download] => [related] => k [product_related] => Array ( [0] => 40 [1] => 45 ) [product_attribute] => Array ( [0] => Array ( [name] => Clockspeed [attribute_id] => 3 [product_attribute_description] => Array ( [1] => Array ( [text] => быстрая ) [2] => Array ( [text] => fast ) ) ) ) [option] => ra [product_option] => Array ( [0] => Array ( [product_option_id] => [name] => Radio [option_id] => 1 [type] => radio [required] => 1 [product_option_value] => Array ( [0] => Array ( [option_value_id] => 31 [product_option_value_id] => [quantity] => 50 [subtract] => 1 [price_prefix] => + [price] => [points_prefix] => + [points] => [weight_prefix] => + [weight] => ) [1] => Array ( [option_value_id] => 43 [product_option_value_id] => [quantity] => 70 [subtract] => 1 [price_prefix] => + [price] => [points_prefix] => + [points] => [weight_prefix] => + [weight] => ) ) ) ) [product_image] => Array ( [0] => Array ( [image] => data/demo/canon_eos_5d_3.jpg [sort_order] => 1 ) [1] => Array ( [image] => data/demo/hp_2.jpg [sort_order] => 2 ) ) [points] => [product_reward] => Array ( [1] => Array ( [points] => ) ) [product_layout] => Array ( [0] => Array ( [layout_id] => ) ) )

Вот такие данные отправляются в Модель при создании категории стандартным контроллером:

Array
(
    [category_description] => Array
        (
            [1] => Array
                (
                    [name] => Название категории
                    [seo_h1] => 
                    [seo_title] => 
                    [meta_keyword] => 
                    [meta_description] => 
                    [description] => 
                )
            [2] => Array
                (
                    [name] => Название категории ENG
                    [seo_h1] => 
                    [seo_title] => 
                    [meta_keyword] => 
                    [meta_description] => 
                    [description] => 
                )
        )
    [parent_id] => 20
    [filter] => 
    [category_store] => Array
        (
            [0] => 0
        )
    [keyword] => category_url
    [image] => data/demo/htc_logo.jpg
    [top] => 1
    [column] => 1
    [sort_order] => 0
    [status] => 1
    [category_layout] => Array
        (
            [0] => Array
                (
                    [layout_id] => 
                )
        )
)

Вот такие данные отправляются в Модель при создании производителя стандартным контроллером:

Array
(
    [name] => Название производителя
    [manufacturer_store] => Array
        (
            [0] => 0
        )
    [keyword] => manuf_url
    [image] => data/demo/apple_logo.jpg
    [sort_order] => 7
    [manufacturer_description] => Array
        (
            [1] => Array
                (
                    [seo_h1] => Название производителя h1
                    [seo_title] => 
                    [meta_keyword] => 
                    [meta_description] => 
                    [description] => 
                )
            [2] => Array
                (
                    [seo_h1] => Название производителя h1 eng
                    [seo_title] => 
                    [meta_keyword] => 
                    [meta_description] => 
                    [description] => 
                )
        )
)

Пример кода для создания производителя:

// Допустим ранее мы уже получили массив с названиями производителей, подключили модель и перевели бабушки через дорогу.
foreach($manufacturers as $v){
	if(!strlen($v)){continue;} // Ну а вдруг..
	$ta = array(); // ta это типа tempArray
	$ta['name'] = $v;
	$ta['image'] = "";
	$ta['keyword'] = "";
	$ta['sort_order'] = $v;
	$ta['manufacturer_store'] = array(0);
	$description = array(
		'seo_h1' => $v,
		'seo_title' => "",
		'meta_keyword' => "",
		'meta_description' => "",
		'description' => "");
	$ta['manufacturer_description'] = array('1' => $description); //Если у нас языков больше чем 1, то надо будет еще для них добавить
	$this->model_catalog_manufacturer->addManufacturer($ta); 
}

Пример кода для создания товара:

// Допустим ранее мы уже получили массив со всеми данными товара, подключили модель и повесили во дворе скворечник.
foreach ($tovar_raw_data as $k=>$row) {
	if(!strlen($row['name'])){
		continue;
	}
	$ta = array();
	
	$product_description = array(
		'name' => $row['name'],
		'seo_h1' => '',
		'seo_title' => '',
		'meta_keyword' => '',
		'meta_description' => '',
		'description' => $row['description_text'],
		'tag' => ''
	);
	$ta['product_description'] = Array(1 => $product_description);
	$ta['model'] = $row['art'];
	$ta['sku'] = '';
	$ta['upc'] = $row['id'];
	$ta['ean'] = "";
	$ta['jan'] = "";
	$ta['isbn'] = '';
	$ta['mpn'] = '';
	$ta['stock_status_id'] = 5;
	$ta['location'] = '';
	$ta['price'] = 0;
	$ta['date_available'] = date("Y-m-d");
	$ta['tax_class_id'] = '';
	$ta['quantity'] = $row['ostatki'];
	$ta['minimum'] = 1;
	$ta['subtract'] = 1;
	$ta['shipping'] = 1;
	$ta['keyword'] = '';
	if(strlen($row['image']) > 5){
		$ta['image'] = $this->uploadImageCTGO($row['image']); // Этот метод описан в резделе "Полезные функции (методы)"
	}else{
		$ta['image'] = "";
	}
	$ta['length'] = '';
	$ta['width'] = '';
	$ta['height'] = '';
	$ta['length_class_id'] = 1;
	$ta['weight'] = '1';
	$ta['weight_class_id'] = 1;
	$ta['status'] = 1;
	$ta['sort_order'] = 1;
	$ta['manufacturer_id'] = $this->getManufacturerIdByName($row['tm']); // Этот метод описан в резделе "Полезные функции (методы)"
	$ta['main_category_id'] = $this->getCateroryIdByName($row['vid']); // Этот метод описан в резделе "Полезные функции (методы)"
	$ta['product_store'] = array(0);
	$ta['related'] = '';
	$ta['option'] = '';
	$ta['points'] = '';
	$ta['product_reward'] = array(1=>array('points'=>0));
	$ta['product_layout'] = array(1=>array('layout_id'=>0));

	$this->model_catalog_product->addProduct($ta);
	//break;
}

Полезные функции (методы), которые встречаются в примерах:

Перевод через Яндекс.Переводчик API. Ксати, вот еще Пример перевода с помощью Yandex Translate API.

public $translated = array(); // К счастью Яндекс ограничивает бесплатный доступ, поэтому оптимизируем код чтобы не делать лишних запросов
public function yTranslate($string){
	$cache_key = md5($string);
	if(array_key_exists($cache_key, $this->translated)){
		return $this->translated[$cache_key];
	}
	$yKey = "--ВАШ КЛЮЧ API--";
	
	$YT_link = "https://translate.yandex.net/api/v1.5/tr.json/translate?key=".$yKey."&text=%s&lang=ru-en";
	$ytranslate = json_decode(file_get_contents(sprintf($YT_link, $string)), true);
	if($ytranslate['code'] == 200){
		$this->translated[$cache_key] = $ytranslate['text'][0];
		return $ytranslate['text'][0];
	}else{
		return $string;
	}
}

Получить ID производителя по его имени

public function getManufacturerIdByName($name){
	$result = $this->db->query("SELECT manufacturer_id FROM oc_manufacturer WHERE name = '".trim($name)."' LIMIT 1");
	if($result->num_rows){
		$manufacturer_id = $result->row['manufacturer_id'];
	}else{
		$manufacturer_id = 0;
	}
	return $manufacturer_id;
}

Получить ID категории по ее имени

public function getCateroryIdByName($name){
	$result = $this->db->query("SELECT category_id FROM oc_category_description WHERE name = '".trim($name)."' ORDER BY language_id LIMIT 1");
	if($result->num_rows){
		$category_id = $result->row['category_id'];
	}else{
		$category_id = 0;
	}
	return $category_id;
}

Загрузка картинок

public function uploadImageCTGO($image_addr){
	$servdir = $_SERVER['DOCUMENT_ROOT'];
	$hashName = md5($image_addr);
	$pathinfo = pathinfo($image_addr);
	$dir = "/image/data/parce_img/";
	if(!empty($pathinfo['extension'])){
		$new_filename = $dir.$hashName.".".$pathinfo['extension'];
		if(!file_exists($servdir.$new_filename)){
			if(!file_exists($servdir.$dir)){
				mkdir($servdir.$dir, 0755);
			}
			try{
				$content = file_get_contents($image_addr);
			}catch(Exception $e){
				$content = false;
			}
			if($content){
				$fp = fopen($servdir.$new_filename, "w");
				fwrite($fp, $content);
				fclose($fp);
				return substr($new_filename, strlen("/image/"));
			}
		}else{
			return substr($new_filename, strlen("/image/"));
		}
	}
}

Транслитизация URL

	public function rus2translit($string) {
		$converter = array(
			'а' => 'a',   'б' => 'b',   'в' => 'v',
			'г' => 'g',   'д' => 'd',   'е' => 'e',
			'ё' => 'e',   'ж' => 'zh',  'з' => 'z',
			'и' => 'i',   'й' => 'y',   'к' => 'k',
			'л' => 'l',   'м' => 'm',   'н' => 'n',
			'о' => 'o',   'п' => 'p',   'р' => 'r',
			'с' => 's',   'т' => 't',   'у' => 'u',
			'ф' => 'f',   'х' => 'h',   'ц' => 'c',
			'ч' => 'ch',  'ш' => 'sh',  'щ' => 'sch',
			'ь' => '\'',  'ы' => 'y',   'ъ' => '\'',
			'э' => 'e',   'ю' => 'yu',  'я' => 'ya',
			
			'А' => 'A',   'Б' => 'B',   'В' => 'V',
			'Г' => 'G',   'Д' => 'D',   'Е' => 'E',
			'Ё' => 'E',   'Ж' => 'Zh',  'З' => 'Z',
			'И' => 'I',   'Й' => 'Y',   'К' => 'K',
			'Л' => 'L',   'М' => 'M',   'Н' => 'N',
			'О' => 'O',   'П' => 'P',   'Р' => 'R',
			'С' => 'S',   'Т' => 'T',   'У' => 'U',
			'Ф' => 'F',   'Х' => 'H',   'Ц' => 'C',
			'Ч' => 'Ch',  'Ш' => 'Sh',  'Щ' => 'Sch',
			'Ь' => '\'',  'Ы' => 'Y',   'Ъ' => '\'',
			'Э' => 'E',   'Ю' => 'Yu',  'Я' => 'Ya',
		);
		return strtr($string, $converter);
	}
	public function str2url($str) {
		$str = $this->rus2translit($str);
		$str = strtolower($str);
		$str = preg_replace('~[^-a-z0-9_]+~u', '-', $str);
		$str = trim($str, "-");
		return $str;
	}
	

Приемы при разборе файлов:

// Пример загрузки файла
$servdir = $_SERVER['DOCUMENT_ROOT'];
$fileFROMxml = "/image/StarKids.xml";
$fileFROMcsv = "/image/tovar.csv";
$dataFROMxml_raw = json_decode(json_encode(simplexml_load_string(file_get_contents($servdir.$fileFROMxml))), true); // XML в массив
$dataFROMcsv_raw = explode("|||||",file_get_contents($servdir.$fileFROMcsv)); // CSV в массив

Вот такие данные отправляются в Модель (помимо id опции) при обновлении опции стандартным контроллером:

Array
(
    [option_description] => Array
        (
            [1] => Array
                (
                    [name] => Размер
                )
        )
    [type] => select
    [sort_order] => 0
    [option_value] => Array
        (
            [0] => Array
                (
                    [option_value_id] => 81
                    [option_value_description] => Array
                        (
                            [1] => Array
                                (
                                    [name] => 7
                                )
                        )
                    [image] => no_image.jpg
                    [sort_order] => 7
                )
            [1] => Array
                (
                    [option_value_id] => 74
                    [option_value_description] => Array
                        (
                            [1] => Array
                                (
                                    [name] => 11
                                )
                        )
                    [image] => no_image.jpg
                    [sort_order] => 15
                )
            [2] => Array
                (
                    [option_value_id] => 73
                    [option_value_description] => Array
                        (
                            [1] => Array
                                (
                                    [name] => 10.5
                                )
                        )
                    [image] => no_image.jpg
                    [sort_order] => 14
                )
        )
)

Создать опцию

// Формируем массив
$option_data = array(
"option_description" => array(
	1 => array("name" => "Размер")
),
"type" => "select",
"sort_order" => 1,
"option_value" => array(),
);

// Получаем данные каким-то образом
$query = "SELECT DISTINCT size FROM catalog_1c_codes ORDER BY size";
$opt_data = $this->db->query($query);

foreach($opt_data->rows as $row){
	$option_data['option_value'][] = array(
			"option_value_description" => array(
				1 => array(
					"name" => $row['size']
				),
				3 => array(
					"name" => $row['size']
				)
			),
			"image" => "no_image.jpg",
			"sort_order" => 0
		);
}

// Подключаем модель и используем ее по назначению
$this->load->model('catalog/option');
$OPTION_ID = 14;
$this->model_catalog_option->editOption($OPTION_ID, $option_data);

Вот такие данные отправляются в Модель ($this->model_sale_customer->addCustomer($this->request->post);) при создании покупателя стандартным контроллером (admin/index.php?route=sale/customer/insert):

Array
(
    [firstname] => Имя, отчество
    [lastname] => Фамиллия
    [email] => email@mail.ru
    [telephone] => телефон
    [fax] => Факс
    [password] => пароль
    [confirm] => пароль
    [newsletter] => 0
    [customer_group_id] => 1
    [status] => 1
    [address] => Array
        (
            [1] => Array
                (
                    [address_id] => 
                    [firstname] => Имя
                    [lastname] => Фамиллия
                    [company] => Компания
                    [company_id] => Регномер компании
                    [tax_id] => инн
                    [address_1] => Адрес
                    [address_2] => Адрес (продолжение):
                    [city] => Город
                    [postcode] => Индекс
                    [country_id] => 10000 //Страна (Россия)
                    [zone_id] => 1028     //Регион
                    [default] => 1
                )
        )
)
/*------------*/
if(isset($data['ctgo'])){
$this->db->query("UPDATE oc_customer SET ip = '".$this->db->escape($data['ip'])."', date_added = '".$this->db->escape($data['date_added'])."' WHERE customer_id = '".$customer_id."'");
return $customer_id;
}

Структура таблицы oc_order_option

  • order_option_idАвтоИнкремент
  • order_idID Заказа (для связи с таблицей oc_order)
  • order_product_idID продукта (для связи с таблицей oc_order_product)
  • product_option_idдля связи с таблицей oc_product_option_value по столбцу product_option_id
  • product_option_value_idдля связи с таблицей oc_product_option_value по столбцу product_option_value_id
  • nameНазвание опции
  • valueЗначение опции
  • typeТип опции
Способ поблагодарить автора сайта:

Комментарии (0)

  1. Напишите первый комментарий
*Комментарий будет опубликован после проверки модератором

[MODx] Подсказки по API

[MODx] minishop2 tips

[Code helper] Заготовки для работы

Преобразовать JSON в HTML

[MODX] Загрузка сниппета после загрузки страницы через AjaxSnippet

[MODX, MiniShop2] Отредактировать письмо о заказе - добавить ТВ поле, или что-то еще

[MODX, pdoCrumbs] Вывести список всех родителей в ТВ поле ресурса

[JS] Связать значения инпутов через jQuery (биндинг)

[MODX] Массово обновить ТВ, или другое поле через базу

[miniShop2] Разместить корзину внутри блока с оформлением заказа

[OpenCart 1.5.1] Массово изменить адреса картинок у товаров

Вывести список всех файлов на сервере (и размер файла)

[PHP] Фиксированная сортировка массива на основе хэша

Курсы валют с cbr.ru на PHP, с запасным вариантом и кэшированием

[MODX] pThumb - ресайз изображений. Примеры использования.

Изменить цену на товар, если в корзине лежит товар из особой категории minishop2

Скрыть информацию о том, что сайт работает на MODX

[MODX] Сообщение о том, что сайт использует Cookie

Не работает подгрузка товаров ajax mfilter2 на мобильном

Постраничная навигация — набор параметров и CSS PdoPage

Разбить вывод pdoResources на несколько колонок (блоков)

[MODX] Добавить скрипт перед тегом body

[PHP] Узнать скорость выполнения кода. Простой таймер PHP

Вывести список всех емэйлов miniShop2

[MODX] Создать редирект через autoRedirector API

[MODX, MiniShop2] Отредактировать шаблон письма

[MODX] Кастомный чанк для AdminPanel

[MODX] Оформление и настройка easyComm. Комментарии и отзывы на сайте.

[MODX, MiniShop2] Обязательный чекбокс при оформлении заказа

[JS] Маска для ввода телефона +7(___)___-__-__

[MODX, MiniShop2] Добавить в письмо контактную информацию

[MODX, MiniShop2] Email сделать не обязательным полем

[MODX] Импорт и экспорт в MiniShop2. Реализация 1

[MODX, MiniShop2] Изменить формат номера заказа

Изменить цену на товар в зависимости от количества при добавлении в корзину minishop2

Общая сумма по каждому товару в корзине Minishop2

reCaptcha не через форму (без тега <form>)

Расширение свойств товаров minishop2

pdoPage и getImageList - Постраничная навигация MIGX

[MODX] Соответствие названия классов с названиями таблиц в MySQL

Вывести 404 ошибку по настройки TV MODX

Расширить таблицу site_content (объект modResource) за 5 минут

Передать файл с одного на другой сервер

Создать ресурс процессором $modx->runProcessor('resource/create', $props)

Как включить HTTPS (SSL) в MODX - Подробная инструкция

[MODX, MIGX] Простейшая авторизация

[MIGX] Простая и симпатичная галерея fancybox

[MODX] Узнать размер файла

Красивое адаптивное меню под pdoMenu

pdoResources Заготовки для работы

FontAwesome - часто используемые иконки для шаблонов MODX

[MODX, MIGX] Тип поля "Список ресурсов" (resourcelist) с ограничением по родителю (parents)

[MODX, MIGX] Вывести getImageList только если он не пустой

Bxslider отображение картинок после полной загрузки слайдера

[MODX] Вывести список всех опций MiniShop2

[MODX] Курсы валют с cbr.ru на PHP

[MODX, MIGX] Простой аудио-плеер HTML5

Как контролировать кэш CSS и скриптов

[OpenCart] Вывести на главную все категории с картинками

[PHP] Получить древовидный массив за один запрос к базе

Вырезать кавычки - фильтр MODx

Регулярное выражение

[MODx] Генератор настроек MIGX

[MODx, MIGx] Документация на русском по MIGx

[MODx] Динамическое поле emailSubject в FormIt

[MODx] Установить шаблон по-умолчанию для новых, создаваемых ресурсов

[MODx,MiniShop2] Не приходит почта администратору

[MODx] Баннеры с использованием BannerY

[Opencart] Вернуть английский язык, если вы его удалили

Универсальная форма обратной связи — feedBackForm

[MODx, miniShop2] Генерация YML для выгрузки в маркет

Редиректы

[MODx] pdoPage pagination css

[MODx] Вывести время загрузки (формирования) страницы

[MODx] Создать источник файлов

[MODx, minishop] Фильтрация по TV параметрам в msProducts

Регулярные выражения notepad++ примеры

[MODx] Создать свою страницу в админке

[JS] Заготовочки

[MODx] Поиск на сайте с пакетом SimpleSearch

[MODx, XML] Ответ для сервиса moneta.ru

[MODx] Подключить MODx в стороннем PHP файле

[MODx] Создать пакет с пользовательской таблицей

[PHP] Простое логирование

[OpenCart] Вывести модуль напрямую через контроллер

[MODx, Gallery] Галерея. Вывести обложки альбомов и фотографии

[MODx, MIGX] Примеры использования

[MODx] Сайт на обслуживании (выключить сайт)

[Opencart, FilterPro] Не работает пагинация

[OpenCart] Заготовки для автоматического заполнения товарами магазина 1.5.5.1.2

[PHP] Разные фишки, заготовки

[PHP, JSON] Пример перевода с помощью Yandex Translate API

[MySQL] Примеры запросов

[MODx] Вывод tv-параметров в формате [название TV] - [значение TV]

[MODx] Дата на русском

[MODx] Ускорить установку MODx revo до пары кликов

[Opencart] API tips

[MODx, Quip] Отсортировать ресурсы по количеству комментариев Quip MODx

[PHP] Загрузить файл для постобработки

[Opencart 2] Показывать в категориях

[MODx, Quip] Более рабочий вариант.

[MODx] Получить grandparent. Вывести родитель родителя

[MODx] Вывести все доступные плейсхолдеры.

[MODx] getResources заготовки

[MODx] Счетчик посещений и скачиваний для сортировки ресурсов

[MODx] Как разместить исходный код сниппета на сайте, в документации

Удалить HTML-теги span, и стили из тега br

Полезные ссылки

Все записи