Импорт документов
Last updated
Last updated
Переключаемся на вторую вкладку «ИМПОРТ/ОБНОВЛЕНИЕ» Для начала импорта необходимо подготовить файл-таблицу Excel от MS Office, либо таблицу Calc в Libre Office, либо файл csv в кодировке UTF-8 или Windows 1251. Пример простой таблицы ниже
Столбец А и В это основные поля документа, а столбец С, соответственно ТВ-параметр. Очередность расположения столбцов может быть любая.
Далее кликаем на заштрихованную область мышкой, либо перетаскиваем наш файл на данную область в модуле.
В случае успеха, у нас отобразится таблица и функционал для начала импорта. Работоспособность модуля не гарантируется в случае сложных таблиц с пустыми столбцами, строками, сложными таблицами с объединёнными ячейками и тд.
ID родителя. Вы можете указать одного родителя для импорта всех документов в таблице
Шаблон. Вы можете указать один шаблон для всех импортируемых документов.
Поле по которому сверяемся. В случае импорта только с учетом обновления данных, вы можете указать поле по которому будет происходить проверка.
Поле соответствия из XLS-таблицы. В случае если поле в таблице и в базе данных не совпадают по именам, можно указать поле из XLS-таблицы.
Поле/TV для замены данных. Дает возможность найти какие то вхождения и заменить их на лету перед импортом в БД сайта.
Снять с публикации перед импортом документы с шаблонами. Опция розволяет перед импортом все документы с определенным шаблоном снять с публикации.
Не добавлять, если нет совпадений. Вы можете запретить добавление новых документов, в случае, если таких документов нет в базе сайта, а вам нужно просто обновить документы, которые есть эксель-таблице и в базе сайта. Например при обновлении прайса на сайте.
Тестовый режим. Импорт без обновления, например посмотреть какие документы совпали по базе, какие нет.
Импорт для MultiCategories. Если у вас установлен плагин MultiCategories, который позволяет выводить один документ в разных категориях (ветках, папках), то вы можете прописать в таблице id данных категорий (через запятую), столбец должен называться category. Также важно чтобы у вас на сайте не было ТВ с именем category.
Допустим вы делаете импорт с документами, у которых разные шаблоны и родители. Тогда просто указываете эти данные в таблице. Данные в таблице имеют больший приоритет чем параметры шаблон и id родителя для всех документов. Даже если они будут указаны, все равно будут использоваться данные из таблицы.
Результат работы импорта в тестовом режиме.
Результат работы импорта в боевом режиме.
Данный модуль умеет определять конечного родителя для непосредственного документам в таблице. Для этого в таблице XLS-файла должны быть указаны специальные названия столбцов: ed_category1#3, ed_category2#4, ed_category3#3 и тд., в зависимости от вложенности, где после разделителя # указывается ID шаблона категории. Последний и окажется конечным родителем для документа. Названия в БД ищутся по полю pagetitle раздела (подраздела). Рассмотрим пример из которого сразу все станет понятно при внимательном рассмотрении.
Это наш файл XLS
А это вид админки с модулем где мы сделали импорт в каталог из 3 уровней вложенности
Таким образом, если даже для какого-то документа нам нужна вложенность два уровня, а третий остается пустой, то для документа сохранится родитель от 2-го уровня.
При использовании хоть одного специального столбца с именем ed_category - параметр ID родителя из общих параметров будет игнорироваться!
Для чего нужно использовать prepare-сниппет? Допустим у вас есть прайс где цены указаны в долларах, а вам нужно чтобы на сайте цены записались в рублях. То есть при импорте перед обновлением prepare-сниппет изменяет данные. При установке модуля у нас создается сниппет-пример, которые можно переименовать и использовать для своих нужд. Сниппетов может быть сколько угодно, в зависимости от ваших задач. Важно чтобы в имени сниппета была запись editDocs. Созданные сниппеты можно в дальнейшем выбрать из выпадающего списка.
Ниже код где показаны какой фрагмент кода срабатывает при каких ситуациях.
Давайте в тестовом режиме сделаем конвертацию на примере простой таблицы. И если данные в тестовом режиме нас устроят можно переключить конвертацию в боевой режим.
Строка 6 - задаем курс доллара. Строка 22 - меняем данные. Все. В данном примере мы цена будет меняться только при апдейте данных, но не при добавлении новых документов. Из кода видно что нужно сделать чтобы данные обрабатывались и при добавлении новых документов.
Таким образом мы можем при помощи prepare-сниппета создавать на лету категории для товаров, если их не существует.
Импорт по количеству товаров не ограничен, но надо понимать, что вывод таблицы в браузере в 20 000 строк, например, притормозит работу браузера.
Обработка 5 000 документов занимает примерно минуту.
Бывают такие ситуации, например, когда вам отдают выгрузку с базой кодов из 1С, а там коды в верхнем регистре, а коды в базе сайта в нижнем регистре. Или в выгрузке есть пробелы в данных по которым хотим делать сравнение. На сайте код ААББ, а в табличке аАБб, например. Либо из-за формата ячеек в числах может точка стоять. Да что угодно. В сниппет у нас передается массив $data с ключами db_srav и xls_srav. Первый это данные из базы сайта, второй это из загружаемой таблички. Для манипулирования данными открываем наш prepare сниппет и добавляем туда код ниже:
Не забываем проверку переменной $process и далее из кода видно что мы переводим значения в нижний регистр и в параметре из таблицы убираем нижнее подчеркивание.
Рассмотрим импорт на следующем примере:
Для этого нам необходим эксель-файл в следующем виде:
где первый столбец у нас будет называться mtv:param1:0, второй mtv:param2:0 и тд., где mtv - имя ТВ параметра (MultiTV), param1 - заголовок (caption) параметра из конфига (НЕ имя, см. скрин ниже), а 0 - номер строки.
После нажатия кнопки "Начать импорт" финальная таблица перестроится с показом какие данные будут загружены в базу.