Генератор объектов (массивы+структуры) для JSON (Fluent)

25.11.24

Разработка - Инструментарий разработчика

Обработка с программным интерфейсом для создания массивов и структур с последовательным вводом данных, точно так же, как они выглядят в JSON запросе.

Скачать файл

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование По подписке [?] Купить один файл
Генератор объектов (массивы+структуры) для JSON (Fluent):
.epf 9,11Kb
4
4 Скачать (1 SM) Купить за 1 850 руб.

Приходилось ли вам по шаблону JSON тела запроса собирать данные для построения объекта: готовить массивы, подготавливать структуры, по окончании сбора одной структуры или массива записывать их как значения в другую структуру или массив?

Если да, то вы попали туда, куда нужно.

Представляю вам Генератор JSON объектов.

Что это такое?

- Обработка с программным интерфейсом, для встраивания в конфигурацию. Построена с помощью паттерна fluent builder (строитель).

Для чего?

- Удобно собирать данные в структуры и массивы структур

 

Кейс использования:


Необходимо собрать данные и отправить запрос в стороннюю систему по REST протоколу. Запрос POST и соответственно формат тела запроса следующий:

{
    "customerData": {
        "name": "Ivan",
        "surname": "Ivanov",
        "children": [
            {
                "name": "Natalya",
                "pets": [
                    {
                        "type": "dog",
                        "name": "Sharik",
                        "age": 10
                    }
                ]
            }
        ]
    }
}

Как бы происходила сборка данных обычными средствами 1С:

Данные = Новый Структура;
Данные.Вставить("name", "Ivan");
Данные.Вставить("surname", "Ivanov");
	
Питомец = Новый Структура;
Питомец.Вставить("type", "dog");
Питомец.Вставить("name", "Sharik");
Питомец.Вставить("age", 10);
	
Питомцы = Новый Массив;
Питомцы.Добавить(Питомец);
	
Ребенок = Новый Структура;
Ребенок.Вставить("name", "Natalya");
Ребенок.Вставить("pets", Питомцы);
	
Дети = Новый Массив;
Дети.Добавить(Ребенок);
	
Данные.Вставить("children", Дети);
	
ОберткаДляЗапроса = Новый Структура;
ОберткаДляЗапроса.Вставить("customerData", Данные);
	
JSON = КоннекторHHTP.ОбъектВJson(ОберткаДляЗапроса);

Наглядно представим схему заполнения структур и массивов

 

 

Видно, что, чтобы заполнить верхний уровень структуры нужно создать нижние: чтобы наполнить массив "pets" нужно для начала создать все объекты pets этого массива, чтобы наполнить массив "children" нужно создать объекты этого массива со всеми объектами подструктур и т.д.

Как бы произошло создание объекта с помощью Генератора JSON объектов:

ОбъектJSON = Обработки.ГенераторJSONОбъектов.Создать().Конструктор()
	.СоздатьСтруктуру()
	.ВставитьИЖдатьЗакрытия("customerData")
		.СоздатьСтруктуру()
		.Вставить("name", "Ivan")
		.Вставить("surname", "Ivanov")
		.ВставитьИЖдатьЗакрытия("children")
			.СоздатьМассив()
			.ДобавитьИЖдатьЗакрытия()
				.СоздатьСтруктуру()
				.Вставить("name", "Natalya")
				.ВставитьИЖдатьЗакрытия("pets")
					.СоздатьМассив()
					.ДобавитьИЖдатьЗакрытия()
						.СоздатьСтруктуру()
						.Вставить("type", "dog")
						.Вставить("name", "Sharik")
						.Вставить("age", 10)
					.Закрыть()
				.Закрыть()
			.Закрыть()
		.Закрыть()
	.Закрыть()
.ПолучитьОбъект();

Схема формирования объекта с помощью Генератора JSON объектов:

 

Функции Генератора в точности повторяют не только действия, но даже вид JSON.

 

Возможности Генератора:

  • Прерывание создания файла в любом месте, обход любых коллекций в цикле и продолжение использования команд Генератора
  • Добавление множества значений в массивы и структуры путем вызова команд "ДобавитьНесколько" и "ВставитьНесколько" для массива и структуры соответственно
  • Передавать на вход конструктор существующий объект типа Массив или Структура:
  • ПользователиМ = Новый Массив;
    ПользователиМ.Добавить("Владимир");
    ПользователиМ.Добавить("Евгений");
    
    Генератор = Обработки.ГенераторJSONОбъектов.Создать();
    ОбъектJSON = Генератор.Конструктор(ПользователиМ)
    	.Добавить("Максим")
    .ПолучитьОбъект();

     

  • Для более собранного вида в строках ДобавитьИЖдатьЗакрытия и ВставитьИЖдатьЗакрытия можно дописывать тип создаваемого значения СоздатьМассив или СоздатьСтруктуру - тогда количество строк кода будет равно строкам JSON: 

  • Генератор = Обработки.ГенераторJSONОбъектов.Создать();
    ОбъектJSON = Генератор.Конструктор().СоздатьСтруктуру()
    	.ВставитьИЖдатьЗакрытия("customerData").СоздатьСтруктуру()
    		.Вставить("name", "Ivan")
    		.Вставить("surname", "Ivanov")
    		.ВставитьИЖдатьЗакрытия("children").СоздатьМассив()
    			.ДобавитьИЖдатьЗакрытия().СоздатьСтруктуру()
    				.Вставить("name", "Natalya")
    				.ВставитьИЖдатьЗакрытия("pets").СоздатьМассив()
    					.ДобавитьИЖдатьЗакрытия().СоздатьСтруктуру()
    						.Вставить("type", "dog")
    						.Вставить("name", "Sharik")
    						.Вставить("age", 10)
    					.Закрыть()
    				.Закрыть()
    			.Закрыть()
    		.Закрыть()
    	.Закрыть()
    .ПолучитьОбъект();

     

Преимущества

  • Понятное чтение и понимание того, что сформируется по итогу
  • Сокращение времени разработки, использование понятных методов вместо постоянного Новый Структура, Новый Массив и т.д.

Проверено на следующих конфигурациях и релизах:

  • 1С:Библиотека стандартных подсистем, редакция 3.1, релизы 3.1.7.220

обработка JSON fluent строитель паттерны паттерн текучий текучие объект массив структура

См. также

Инструментарий разработчика Роли и права Запросы СКД Программист Руководитель проекта Платформа 1С v8.3 Управляемые формы Запросы Система компоновки данных Платные (руб)

Инструменты для разработчиков 1С 8.3: Infostart Toolkit. Автоматизация и ускорение разработки на управляемых формах. Легкость работы с 1С.

12000 руб.

02.09.2020    171703    960    403    

924

Инструментарий разработчика Чистка данных Свертка базы Инструменты администратора БД Системный администратор Программист Руководитель проекта Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Россия Платные (руб)

Инструмент представляет собой обработку для проведения свёртки или обрезки баз данных. Работает на ЛЮБЫХ конфигурациях (УТ, БП, ERP и т.д.). Поддерживаются серверные и файловые базы, управляемые и обычные формы. Может выполнять свертку сразу нескольких баз данных и выполнять их автоматически без непосредственного участия пользователя. Решение в Реестре отечественного ПО

8400 руб.

20.08.2024    14255    108    46    

108

Инструментарий разработчика Программист Платформа 1С v8.3 1C:Бухгалтерия Платные (руб)

Инструмент для написания и отладки кода в режиме «1С:Предприятие». Представляет собой консоль кода с возможностью пошаговой отладки, просмотра значений переменных любых типов, использования процедур и функций, просмотра стека вызовов, вычисления произвольных выражений на встроенном языке в контексте точки останова, синтаксического контроля и остановки по ошибке. В консоли используется удобный редактор кода с подсветкой, контекстной подсказкой, возможностью вызова конструкторов запроса и форматной строки.

9360 руб.

17.05.2024    27244    96    48    

137

Пакетная печать Печатные формы Инструментарий разработчика Программист Платформа 1С v8.3 Запросы 1С:Зарплата и кадры бюджетного учреждения 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 Платные (руб)

Инструмент, позволяющий абсолютно по-новому взглянуть на процесс разработки печатных форм. Благодаря конструктору можно значительно снизить затраты времени на разработку печатных форм, повысить качество и "прозрачность" разработки, а также навести порядок в многообразии корпоративных печатных форм.

22200 руб.

06.10.2023    17256    43    15    

75

Инструменты администратора БД Инструментарий разработчика Роли и права Программист Платформа 1С v8.3 1C:Бухгалтерия Россия Платные (руб)

Расширение позволяет без изменения кода конфигурации выполнять проверки при вводе данных, скрывать от пользователя недоступные ему данные, выполнять код в обработчиках. Не изменяет данные конфигурации, легко устанавливается практически на любую конфигурацию на управляемых формах.

15000 руб.

10.11.2023    11888    45    27    

67

SALE! %

Инструментарий разработчика Инструменты администратора БД Системный администратор Программист Платформа 1С v8.3 Управляемые формы 1C:Бухгалтерия Россия Платные (руб)

Универсальный инструмент программиста для администрирования конфигураций. Сборник наиболее часто используемых обработок под единым интерфейсом.

4800 3840 руб.

14.01.2013    191158    1152    0    

920

Инструментарий разработчика Платформа 1С v8.3 1C:Бухгалтерия 1С:ERP Управление предприятием 2 Платные (руб)

Разработка Конструктор автоматизированных рабочих мест "Конструктор АРМ" реализована в виде расширения и является универсальным инструментом для создания АРМ любой сложности в пользовательском режиме.

3600 руб.

27.12.2024    1112    2    0    

5

Инструментарий разработчика Программист Платформа 1С v8.3 1C:Бухгалтерия Россия Платные (руб)

Восстановление партий или взаиморасчетов, расчет зарплаты, пакетное формирование документов или отчетов - теперь все это стало доступнее. * Есть желание повысить скорость работы медленных алгоритмов! Но... * Нет времени думать о реализации многопоточности? * о запуске и остановке потоков? * о поддержании потоков в рабочем состоянии? * о передаче данных в потоки и как получить ответ из потока? * об организации последовательности? Тогда ЭТО - то что надо!!!

5000 руб.

07.02.2018    104111    244    100    

307
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. mszsuz 337 25.11.24 12:43 Сейчас в теме
А как вам такой вариант:
Данные = ЕХТ.Структура(
	"customerData", ЕХТ.Структура(
		"name", "Ivan",
		"surname", "Ivanov",
		"children", ЕХТ.Массив(
			ЕХТ.Структура(
				"name", "Natalya",
				"pets", ЕХТ.Массив(
					ЕХТ.Структура(
						"type", "dog",
						"name", "Sharik",
						"age", 10))))));
ДанныеJSON = ЕХТ_Значение.вJSONДляПросмотра(Данные);
ЕХТ.Вывести("Данные: <ПС> %1", ДанныеJSON);
Показать
Прикрепленные файлы:
GrigoryYanshin; +1 Ответить
3. bayselonarrend 2385 25.11.24 12:49 Сейчас в теме
2. bayselonarrend 2385 25.11.24 12:47 Сейчас в теме
Имхо, все это будет выглядеть не так элегантно, когда вместо отдельного формирования вложенных коллекций (создание которых можно и в отдельные функции вынести) придется внутрь этих конструкций вставлять циклы, выборку из запросов, условия и всякое формирование данных другое
4. mszsuz 337 25.11.24 13:09 Сейчас в теме
(0) а "pets" точно в "children" в условиях задачи? )
Оставьте свое сообщение