Выгрузка и чтение JSON

13.08.25

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

Реализация записи и чтения объектов методами JSON с реализацией сохранения и выгрузки файла для самых маленьких БЕСПЛАТНО без смс и регистрации.

Файлы

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

Наименование Скачано Купить файл
Выгрузка JSON
.epf 9,28Kb
6 1 850 руб. Купить

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

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

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

Добрый день, сегодня хочу предоставить вам самый простейший способ реализации JSON в 1С.

Разберу его на примере выгрузки документа в жсон строку с последующей конвертацией ее в файл, а также его чтения и выгрузки из файла

Для начала разберем чтение, мы добавляем интересующие нас документы в табличную часть



После чего начинаем читать данные документа и записываем их в массив, дабы перевести эти данные в строку JSON:

Функция ВыгрузитьНесколькоНаСервере() 
	
	//Создание массива куда будут грузится структуры с данными
	МассивJSON = Новый Массив;
	СтрокаJSON = "";
	//Цикл для выбора нужного дока/справочника из ТЧ
	Для Каждого СтрокаТЧ Из МетаданныеТЧ Цикл 		
		ДокументТЧМета = СтрокаТЧ.СсылкаНаДокументы.Метаданные(); 
		
		//Вытаскивание переменных из выбранного документа/справочника
		ДокументТЧМета.ПолноеИмя();
		Попытка
			Наименование = СтрокаТЧ.СсылкаНаДокументы.Наименование;
		Исключение  
			Наименование = "";
		КонецПопытки;     
		ГУИД = СтрокаТЧ.СсылкаНаДокументы.УникальныйИдентификатор();
		ГУИДСтрока = Строка(ГУИД);
		ПолноеИмяСтроки = ДокументТЧМета.ПолноеИмя();
		ИмяОбъекта = СтрРазделить(ПолноеИмяСтроки, ".")[1];  
		ТипОбъекта = СтрРазделить(ПолноеИмяСтроки, ".")[0];	
		
		//Создание переменных в структуре 
		Структура = Новый Структура();  
		Структура.Вставить("ТипОбъекта", ТипОбъекта);
		Структура.Вставить("ИмяОбъекта", ИмяОбъекта);  
		Структура.Вставить("УИДСсылки", ГУИДСтрока);
		Структура.Вставить("Наименование", Наименование); 
		
		//Записываем все отработанные структуры в массив
		МассивJSON.Добавить(Структура);
	КонецЦикла;
	
	//Запись в формат Джисон
	ПараметрыJSON = Новый ПараметрыЗаписиJSON(, Символы.Таб);
	ЗаписьJSON = Новый ЗаписьJSON;	
	ЗаписьJSON.УстановитьСтроку(ПараметрыJSON);
		
	ЗаписатьJSON(ЗаписьJSON, МассивJSON, Новый НастройкиСериализацииJSON); 
	СтрокаJSON = СтрокаJSON + ЗаписьJSON.Закрыть();	 
		
КонецФункции

Таким образом, мы получили строку со следующим видом:



В дальнейшем, даже если мы полностью очистим ТЧ, то при нажатии на кнопку Найти документ, будет выполнен следующий код:

Процедура НайтиДокНаСервере()
	
	МетаданныеТЧ.Очистить();
	
	//Читаем текст, что было выгружено
	Чтение = Новый ЧтениеJSON;
	Чтение.УстановитьСтроку(ЭтотОбъект.СтрокаJSON);
	МассивJSON = ПрочитатьJSON(Чтение, Ложь); 
	
	//Получаем данные каждой структуры входящей в массив 
	Для Каждого Строка из МассивJSON Цикл
		УИДJSON = Строка.УИДСсылки; 
		ТИПJSON = Строка.ТипОбъекта;
		ИМЯJSON = Строка.ИмяОбъекта;  		
		ГУИД = Новый УникальныйИдентификатор(УИДJSON);
		
		//Получение полного пути до файла путем соединения реквизитов структуры
		ПолноеИмя = ТИПJSON+"."+ИМЯJSON; 
		//Обращение к методам БСП который самостоятельно по полному имени находит тип к примеру "Документ.Номенклатура"
		ПутьЧерезТипИИмя = ОбщегоНазначения.МенеджерОбъектаПоПолномуИмени(ПолноеИмя);
		//Получаем конкретный документ который ищем по ГУИДУ к примеру "Деликатес №2 С.НАР запеч(180г)"
		ОбьектСсылка = ПутьЧерезТипИИмя.ПолучитьСсылку(ГУИД); 
		
		//Строка ТЧ из массива
		стрТч = МетаданныеТЧ.Добавить();
		//Ссылка на ТЧ на форме и погружение в ТЧ Дока который мы нашли
		стрТч.СсылкаНаДокументы = ОбьектСсылка;   
	КонецЦикла;
	
КонецПроцедуры

И таким образом мы заполним нашу табличную часть данными, которые мы получили, прочитав строку жсон.

Если же вас заинтересовал процесс асинхронной выгрузки строки в файл, то вот данные:

&НаКлиенте
Процедура Команда1(Команда)
	// Вставить содержимое обработчика.  
	
	ДиалогВыбораФайла = Новый ДиалогВыбораФайла(РежимДиалогаВыбораФайла.Сохранение);
    ДиалогВыбораФайла.Фильтр = "jsn(*.json)|*.json";
  
    ПараметрыСценария = Новый Структура;
    Оповещение = Новый ОписаниеОповещения("КаталогНачалоВыбораЗавершение", ЭтаФорма);
    ПараметрыСценария.Вставить("Оповещение_ПослеЗакрытияДиалогаВыбораФайла", Оповещение);
    ПараметрыСценария.Вставить("ДиалогВыбораФайла", ДиалогВыбораФайла);
	
	ДиалогВыбораФайла.Показать(Оповещение); 
		
КонецПроцедуры 

Таким образом делается сохранение объектов, а вот их выгрузка:
 

&НаКлиенте                                                               
Процедура ОткрытьФайл(Команда)   
	
	//Часть отвечающая за выбор файла
	ДиалогВыбора = Новый ДиалогВыбораФайла(РежимДиалогаВыбораФайла.Открытие);
	ДиалогВыбора.Заголовок = "Выберите файл"; 
	
	Если ДиалогВыбора.Выбрать() Тогда
	
		ИмяФайла = ДиалогВыбора.ПолноеИмяФайла; //Выбор файла из диалогового окна

	КонецЕсли;
	
	//Условия для чтения файла JSON
	ЧтениеJSON = Новый ЧтениеJSON; 
	ЧтениеJSON.ОткрытьФайл(ИмяФайла); 
	
	Пока ЧтениеJSON.Прочитать()Цикл
		ТипJSON = ЧтениеJSON.ТипТекущегоЗначения;
		
		 Если ТипJSON	   = ТипЗначенияJSON.Число Или ТипJSON = ТипЗначенияJSON.Строка Или
			  ТипJSON 	   = ТипЗначенияJSON.Булево Или ТипJSON = ТипЗначенияJSON.Null Тогда  
			  Значение 	   = ЧтениеJSON.ТекущееЗначение;
		 ИначеЕсли ТипJSON = ТипЗначенияJSON.Комментарий Тогда
			  Комментарий  = ЧтениеJSON.ТекущееЗначение;
		 ИначеЕсли ТипJSON = ТипЗначенияJSON.ИмяСвойства Тогда
			  ИмяСвойства  = ЧтениеJSON.ТекущееЗначение;
		 ИначеЕсли ТипJSON = ТипЗначенияJSON.НачалоМассива Или ТипJSON = ТипЗначенияJSON.КонецМассива ИЛИ
			 	   ТипJSON = ТипЗначенияJSON.НачалоОбъекта Или ТипJSON = ТипЗначенияJSON.КонецОбъекта ИЛИ
				   ТипJSON = ТипЗначенияJSON.Ничего Тогда
		 КонецЕсли;	 
	 КонецЦикла;
	 
	 ЧтениеJSON.Закрыть();
	 
	 //Вывод результата в строку на форме
	 ЭтотОбъект.СтрокаJSON = Значение;
	 
КонецПроцедуры

И на этом у меня все )

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

  • 1С:ERP Управление предприятием 2, релизы 2.5.23.66

Вступайте в нашу телеграмм-группу Инфостарт

JSON Чтение Выгрузка Сериализация Перенос документов Массив Внешняя обработка

См. также

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

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

15500 руб.

02.09.2020    215679    1190    413    

1052

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

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

22200 руб.

06.10.2023    27206    69    30    

99

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

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

9500 руб.

17.05.2024    38540    140    55    

178

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

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

16000 руб.

10.11.2023    19266    76    39    

92

Инструментарий разработчика Нейросети Платные (руб)

Первые попытки разработки на 1С с использованием больших языковых моделей (LLM) могут разочаровать. LLMки сильно галлюцинируют, потому что не знают устройства конфигураций 1С, не знают нюансов синтаксиса. Но если дать им подсказки с помощью MCP, то результат получается кардинально лучше. Далее в публикации: MCP для поиска по метаданым 1С, справке синтакс-помошника и проверки синтаксиса.

9900 руб.

25.08.2025    5454    9    10    

18

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

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

5000 руб.

27.12.2024    3904    7    0    

12

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

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

6000 руб.

07.02.2018    108590    249    100    

313
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. SerVer1C 989 15.08.25 19:10 Сейчас в теме
Кстати, в последних БСП версии 3.1 фирма 1С сделала универсальную выгрузку объектов в различные форматы
2. n_mezentsev 62 16.08.25 18:05 Сейчас в теме
ЗначениеВФайл может сохранить в файл даже ТаблицуЗначений, правда работает только на сервере и в толстом клиенте, работает быстрее, чем все эти операции с JSON
Для отправки сообщения требуется регистрация/авторизация