Функции для преобразования справочников и документов в соответствие и обратно

03.11.22

Разработка - Универсальные функции

Функции для преобразования справочников и документов в соответствие и обратно. Предназначены для передачи данных между одинаковыми и не очень конфигурациями или как очередной вариант сохранения (архивирования) объектов перед редактированием с последующим восстановлением.

Задумывались для передачи объектов через web или http сервисов между базами 1С. Также можно использовать для разных конфигураций, для чего понадобится небольшая доработка для получения названий справочников конфигурации приемника.

+ бонусом процедура определения значений простого типа:) 

Советы:

Для уменьшения размера при передаче можно предварительно поместить в сжатое хранилище значений:

Хранилище = Новый ХранилищеЗначения(СоответствиеОбмен,Новый СжатиеДанных(9));

Кроме того хранилище хорошо сериализуется в XML строку, с которой тоже можно делать много полезного.

При создании элемента справочника при загрузке используется СтрЗаменить(ПолноеИмяОбъекта,"Справочник.",""), тут можно вызвать процедуру для описания соответствий имен справочников и документов разных конфигураций

Внимание: Не отлажено на 100%, черновой вариант - больше для описания концепции.

 

 
 Функция определения сложности типа и получения соответствия имени
 
 Функция для помещения объекта в соответствие
 
 Функция для получения объекта из соответствия


10.11.2021:  Функция помещения в соответствия модернизирована: добавлена защита от зацикливания и описание работы с некоторыми типами значений реквизитов. Перед использований обратите внимания, что возможно потребуется отладка и доработка функции возвращения обратно в объект, ее пока не правил.

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

См. также

Загрузка и выгрузка в Excel Универсальные функции Программист 1С:Предприятие 8 Россия Бесплатно (free)

Описанный ниже подход позволяет в три шага заполнять формулы в Excel файлы, вне зависимости от ОС сервера (MS Windows Server или Linux). Подход подразумевает отказ от работы с COM-объектом в пользу работы через "объектную модель документа" (DOM).

30.10.2025    3616    Abysswalker    9    

45

Универсальные функции Работа с интерфейсом Программист 1С:Предприятие 8 Бесплатно (free)

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

14.05.2025    6716    DeerCven    15    

59

Универсальные функции Программист 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

Благодаря этим пяти строчкам можно больше не заморачиваться с загрузкой из внешних файлов. Пользуюсь везде, всегда и постоянно.

21.05.2024    49682    dimanich70    83    

170

Универсальные функции Программист 1С:Предприятие 8 1C:Бухгалтерия Абонемент ($m)

Задача: вставить картинку из буфера обмена на форму средствами платформы 1С.

1 стартмани

18.03.2024    7390    6    John_d    13    

59

Универсальные функции Программист Стажер 1С:Предприятие 8 1C:Бухгалтерия Бесплатно (free)

Пришлось помучиться с GUID-ами немного, решил поделиться опытом, мало ли кому пригодится.

12.02.2024    62391    atdonya    31    

70

Универсальные функции Программист 1С:Предприятие 8 Бесплатно (free)

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

30.11.2023    9223    ke.92@mail.ru    17    

68
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. ixijixi 2097 01.11.21 10:27 Сейчас в теме
Вот это
Если СтрНайти(Объект.Метаданные().ПолноеИмя(),"Справочник")<>0 Тогда
           Соответствие.Вставить("Наименование",Объект.Наименование);
           Соответствие.Вставить("Код",Объект.Код);
    ИначеЕсли СтрНайти(Объект.Метаданные().ПолноеИмя(),"Документ")<>0 Тогда    
           Соответствие.Вставить("Номер",Объект.Номер);
           Соответствие.Вставить("Дата",Объект.Дата);
    КонецЕсли;

лучше заменить на
Для Каждого Реквизит Из Объект.Метаданные().СтандартныеРеквизиты Цикл
	Соответствие.Вставить(Реквизит.Имя, Объект[Реквизит.Имя]);
КонецЦикла;

т.к. у справочника например может не быть кода и/или наименования
DrAku1a; 0x00; avalakh; +3 Ответить
2. avalakh 581 01.11.21 11:09 Сейчас в теме
(1) Соглашусь, это будет правильнее. Подправил
3. JohnyDeath 302 05.11.21 19:21 Сейчас в теме
Вот в тему отличный опенсорсный проект. Подписываемся, ставим лайки, делаем пул-реквесты )
https://github.com/arkuznetsov/SerLib1C
artbear; cleaner_it; avalakh; +3 Ответить
4. DrAku1a 1787 06.11.21 14:31 Сейчас в теме
Один вопрос только: Почему соответствие, а не структура?
5. avalakh 581 09.11.21 16:49 Сейчас в теме
(4) тут не принципиально. Но в данном случае, что бы использовать готовые процедуры преобразования из соответствия в json и обратно, найденные в интернете. Ссылку не дам - не помню где видел, но точно где то есть. Вдруг кому понадобится, а уже все готово, а переделать на структуру, если понадобится, не долго
Для отправки сообщения требуется регистрация/авторизация