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

24.04.25

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

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

Файлы

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

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

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

Приходилось ли вам по шаблону 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С.

15500 руб.

02.09.2020    205619    1129    410    

1027

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

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

8400 руб.

20.08.2024    36767    211    109    

198

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

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

16000 руб.

10.11.2023    16763    73    39    

89

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

Расширение для создания и редактирования печатных форм в системе 1С:Предприятие 8.3. Благодаря конструктору можно значительно снизить затраты времени на разработку печатных форм, повысить качество и прозрачность разработки, а также навести порядок в многообразии корпоративных печатных форм.

22200 руб.

06.10.2023    24344    65    28    

93

Инструментарий разработчика Программист 1С v8.3 1С:Управление нашей фирмой 3.0 Платные (руб)

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

9500 руб.

17.05.2024    35235    127    53    

168

SALE! 30%

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

Инструмент для генерации OpenApi (Swagger) спецификаций на основании файлов конфигураций 1С. Это консольное и десктопное приложение на языке Rust с полноценным редактором кода, содержащим автозамену и подсвечивание ошибок для быстрого и безошибочного написания документирующего комментария.

18000 12600 руб.

22.11.2024    2008    1    0    

8

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

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

6000 руб.

07.02.2018    107666    249    100    

313
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. mszsuz 343 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 2862 25.11.24 12:49 Сейчас в теме
2. bayselonarrend 2862 25.11.24 12:47 Сейчас в теме
Имхо, все это будет выглядеть не так элегантно, когда вместо отдельного формирования вложенных коллекций (создание которых можно и в отдельные функции вынести) придется внутрь этих конструкций вставлять циклы, выборку из запросов, условия и всякое формирование данных другое
4. mszsuz 343 25.11.24 13:09 Сейчас в теме
(0) а "pets" точно в "children" в условиях задачи? )
Оставьте свое сообщение