Quad.Wiki

Skip to end of metadata
Go to start of metadata

You are viewing an old version of this page. View the current version.

Compare with Current View Page History

« Previous Version 22 Next »

Загрузка товаров из файла YML

Импорт настраивается через задание Quad.Magic, тип задания в группе Импорт, Импорт YML.


Настройка 1 - указывается путь к файлу, который нужно загрузить.

Настройка 2 - выбирается настройка прайса, в которую будет загружен файл (ее нужно предварительно добавить во вкладке Прайсы/внизу 3. Настройка прайсов). Если в этой настройке ничего не указано, то файл загружается в Основной прайс (вкладка Продукция).

Настройка 3 - указываются настройки загрузки файла.

Вкладка "Импорт"


Записать ID в поле - указывается поле, в которое будет записано offer id из прайса. Это же поле будет использоваться для определения уникальности товара, т.е. по нему будет загрузка прайса. Если id в прайсе содержит текст, а не число, то и поле нужно выбирать с типом "Строка"

vendorCode + offer ID - данная настройка нужна в случае, если в файле YML не указано offer ID или если оно дублируется. Если установлена эта птичка, то ид товара будет загружаться как  сумма полей vendorCode + offer ID

в примере выше в ид товара запишется 10418_4

Ссылка на фото - поле, в которое записываются все ссылки на фото из тегов <picture>, если такие есть в файле YML. Разделитель между ссылками - точка с запятой.


Модель - выбирается какие поля из файла будут записаны в модель товара

Название - указывается, как будет формироваться название товара, из каких полей файла.

Префикс в названии - если установлена птичка, то в начало названия товара будет добавляться префикс из тега typePrefix

Загружать производителей - если птичка установлена, то будет загружен бренд из тега vendor

Загружать категории - при установленной птичке из файла YML загружаются группы товаров из тега categories

Загружать характеристики в поле - выбирается поле, в которое, при установленной птичке, будут загружены параметры из файла YML в виде текстовой таблицы. Если установить дополнительно птичку "В виде описания Quad.Net", то характеристики загрузятся в необходимом для программы формате, чтобы она могла при помощи QuadSite сформировать отдельные характеристики для фильтров.

Загружать описание в поле - выбирается поле, в которое загружается информация из тега description файла YML, при установленной птичке.

Конвертировать валюту - указываются коды валют, из какой и в какую будут конвертированы цены этого прайса, при этом будет взят соответствующий курс из файла YML из тега currencies. Например, если в файле цены в рублях, а нужно их по курсу прайса конвертировать в доллары, то нужно написать из валюты RUR в валюту USD, если валюты указаны как на скриншете ниже. Цены в рублях будут умножены на 64.5

Иногда нужно наоборот, разделить на указанный в файле курс, в этом случае выбирается "разделить"


Проверить по названию, если не нашло по ID - при установленной птичке при загрузке прайса YML программа сначала ищет нет ли в базе товара по offer id и если нет - проверяет дополнительно по названию товара. Если рядом с птичкой указать код какого-нибудь поля, то дополнительная проверка будет брать название товара из файла и искать соответствие в значении этого поля (это можно использовать когда названия товаров из файла YML вы храните в каком-то другом поле).


Нет в наличии, если available = false - если стоит эта птичка, товары у которых в файле указано в параметре available значение false будут загружаться как Нет в наличии. По умолчанию для формата YML (если не установлена птичка) товары такие будут загружены со статусом "Под заказ". Если тег available=”” , т.е. пусто, то товар будет загружен как Нет в наличии.

Если true , то товар будет В наличии.

' вместо " - бывает в файле YML вместо кавычек используют апостроф - в этом случае нужно поставить эту птичку

group_id (Deal, Prom) - можно выбрать поле, в которое загрузится параметр group_id из файла YML, с помощью которого связываются модификации товаров. Это поле можно будет использовать для обратной выгрузки в файл.


Сохранять историю - если установлена птичка, то по прайсу будет сохраняться история изменения цен и наличия.

Вкладка Импорт (дополнительно)

Здесь можно указать правила для загрузки информации из произвольных тегов и параметров.

Для загрузки информации из тегов со скриншета выше используется следующее правило:

FLD|barcode|f_3uffduguk

FLD - означает, что загружать нужно тег

barcode - название тега

f_3uffduguk- поле в программе, в которое загружается информация из тега, может быть стандартное (уточните в поддержке как его записать здесь), либо дополнительное пользовательское поле

Коды стандартных полей можно посмотреть здесь в п.4: Полезные SQL-запросы

Если загружать информацию  из тега нужно в числовое поле, то нужно указать в конце еще дополнительно |1 , т.е. все вместе будет так: FLD|barcode|f_3uffduguk|1

Чтобы загрузить параметр (начинается с тега param) из файла, нужно указать такое значение, пример PRM|Цвет|F_3S0K6P1GE

PRM - означает, что загружать нужно параметр

Цвет - название параметра

F_3S0K6P1GE - поле в программе, в которое загружается информация из параметра


Каждое правило указывается с новой строки.

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

Если из прайса нужно загрузить Рекомендованную цену (РРЦ), то настройка будет такой:

FLD|price_rrc|fixed_price|1

где price_rrc - тег в прайсе, в котором находится РРЦ.

Бывает поставщик дополняет формат YML какими-то своими дополнительными полями в каком-то произвольном виде, которые нельзя загрузить ни как тег, ни как параметр - в этом случае можно "вырезать" нужный текст из файла с помощью указания текста, который находится слева и справа от нужного значения. Для этого используется тег ANY. Например, поставщик в файле выводит 2 цены, оптовую и розничную в таком виде:

Цену рекомендованную мы можем получить если вырежем текст, который находится между "RRP" currencyId="KZT"> и </price>


Правило можно записать так:

ANY|[QT]RRP[QT] currencyId=[QT]KZT[QT]>|</price>|fixed_price|

кавычки в правилах заменяются на [QT]

fixed_price - код поля Рекомендованная цена (МРЦ)

Пример получившихся правил:


Сохранение остатков (количества товара)

Формат YML не предусматривает какого-то стандартного тега, в котором бы передавались реальные остатки товара, но поставщики могут их добавлять в виде произвольного тега или же параметра. В этом случае, остатки загружаются через PRM или FLD.

Если передается текстовый остаток, то загружается он в поле exists_text. Если передается числовой остаток, то загружается в поле stock.

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

В файле поставщика это выглядит так:

Т.е. поставщик указывает значение текстовое “>100”

Чтобы по текстовому значению указать наличие и числовой остаток, делаются настройки наличия в прайсе.

После настройки импорт товаров из файла осуществляется этим действием Quad.Magic. Во вкладке Загрузка прайсов ничего делать не нужно, там загружаются только прайсы через Excel.

Импорт XML

Для импорта файла XML, который не соответствует формату YML, вам нужно при его получении сохранять с расширением XLS и пробовать открыть в Excel. В большинстве случаев прайс открывается корректно и его можно загрузить как обычный Excel. Если файл открывается "криво" или не открывается в экселе, то можно попробовать сделать Импорт XML в новых версиях Excel (2016 с последними обновлениями или 2019) и записать во время импорта макрос. Если открыть в экселе не получается и с помощью макроса, нужно разрабатывать специальный скрипт, который преобразует ваш файл XML в табличный вид. Скрипт разрабатывается за дополнительную оплату, либо можете сделать его сами, инструкция:

Импорт XML через Excel






  • No labels