VA СамописныйШаг по заполнению Excel для загрузки в документ
Собственный шаг *.epf для библиотеки Vanessa Automation, который способен создать *.xlsx для загрузки в ТЧ документа.
1. Создание обработки и макетов
2. Объявление табличных данных макета
3. Получение данных из запроса, геркин-таблицы
Кратко о работе шага:
- 1 вариант: в шаге можно передать заголовки геркин-таблицы (по сути с любые) в количестве 1-ой строки, тогда все данные для заполнения макетов для создания Excel будут браться из запроса к базе. При этом, параметры в синтаксисе шага - будут переданы в функцию, где выполняется запрос.
- 2 вариант: в отличие от 1-го варианта, если в геркин-таблице указать 2-ую строку со значениями, тогда к заголовку полей будут присвоены эти значения как Соответствие пары ключ-значение. При этом, параметры переданные в синтаксисе шага - будут проигнорированы.
№1Для начала необходимо создать внешнюю обработку *.epf шага. Создать макеты по которым будет заполняться и сохраняться *.xlsx:

- 1-ой строкой идёт область "Шапка"с заголовками которые хочу получить в файле Excel.
- 2-строкой идёт область "Бюджет"с <Параметры>, которые заполняются значениями по структуре - полученными в зависимости от варианта (см. выше) получения данных.
№2Теперь через Функцию "ДанныеПоИсточникамНаСервере" определяем области макета и параметры табличных данных полей, которые будем заполнять в макете построчно:
№3Для 2-х вариантов использования самописного шага - получения данных для макетов:
- с 1-ой строкой геркин-таблицы - возвращает "ТаблицаЗначений" из запроса в функции "ДанныеКорректировкиБюджетовИзБазы"
- с >1-ой строками геркин-таблицы: возвращает Соответствие заголовков полей и их значений как массив структур функции "ТаблицаГеркенВМассивСтруктуру" для заполнения контейнера данных "ДанныеКорректировкиБюджетов".
ДанныеКорректировкиБюджетов определяют состав полей: по 1-му варианту из запроса, 2-му - из таблицы-геркин:
3.1 Заполнение из запроса (вариант 1):

3.2 Заполнение из геркин-таблицы (вариант 2):

№4Когда сгенерируется Excel, одновременно создётся эталонная таблица для будущего сравнения с заполненной после загрузки таблицей в документе. Результатом представления является "ПредставлениеТаблицыНаФорме" - массив, где каждый элемент это Соответствие пары ключ-значение (пример "Вид бюджета" = "Бюджет начислений") как эталон, сохраненный через контекст в переменную "Л_ПредставлениеТаблицыНаФорме". Поэтому, далее в шагах сценария, я сверяю её с реально получившейся после загрузки ТЧ Источника и Получателя:

№5Добавляем в библиотеку Vanessa Automation сохраненный самописный шаг *.epf. Запускаем его в сценарии через прописанный синтаксис: в зависимости от выбранного варианта генерации данных для макета - создаётся Excel файл, который загружаем посредством следующих шагов библиотеки и сравниваем эталон с сформированной таблицей документа:

Похожие материалы (по тегу)
- Заполнить на форме внешней обработки таблицу значений из результата запроса
- Консоль запроса: подсчёт количества документов в группировке по детальным записям
- Свёртка базы 1С УТ 10.3
- Как вывести Регистратор и Период по регистру бухгалтерии и выбрать тип регистратора в СКД
- СКД вывести последний документ по номенклатуре если не было оборота по регистру в выбранном периоде