Инструменты обмена данными через xml используя сериализацию объектов

10.07.24

Интеграция - Файловый обмен (TXT, XML, DBF), FTP

Восстановление справочников, документов, регистров сведений из копии через xml, используя сериализацию объектов. Выгрузка/загрузка объектов базы данных в xml, используя сериализацию. Выгрузка/загрузка таблицы значений в xml, используя сериализацию.

Предыстория: 

Конфигурация 1С на платформе 8.3. В ней есть замечательный механизм "поиск и замена ссылок". Переносил данные из нескольких баз на платформе 7.7 в одну базу на платформе 8.3. Элементы некоторые справочников задублировались (ключевые поля имели незначительные отличия в базах, хотя описывали одну сущность). Использовав механизм "поиска и замены" свернул эти справочники. Через несколько рабочих дней выяснилось, что пропало одно подразделение. Восстановил копию, проверил, на это подразделение в копии более 7 тысяч ссылок. Предприятие отработало на свернутой базе уже несколько дней, восстанавливаться из копии не вариант.

1) С чего начал: Функция НайтиПоСсылкам(МассивСсылок) - возвращает таблицу значений, содержащую Описание метаданных и ссылку на объект, содержащий искомую ссылку. Не все прошло гладко, поэтому некоторые документы догружал, получив выборку ссылок запросом. Вначале перенес элементы справочников, которые сворачивались, и которые содержались в документах со ссылкой на восстанавливаемое подразделение. 

Для выгрузки использовал вот такой кусок кода:

//Выгрузка объектов (справочников, документов) в xml используя сериализацию

ЗаписьXML = Новый ЗаписьXML;
ЗаписьXML.ОткрытьФайл(ИмяФайла);
   ЗаписьXML.ЗаписатьНачалоЭлемента("Root");

       // допустим у нас есть Выборка из запроса, которая содержит ссылки на объекты
       Пока Выборка.Следующий() Цикл
          ЗаписьXML.ЗаписатьНачалоЭлемента("НовыйОбъект");
             лОбъект = Выборка.Ссылка.ПолучитьОбъект();
             ЗаписатьXML(ЗаписьXML,лОбъект);
          ЗаписьXML.ЗаписатьКонецЭлемента();
       КонецЦикла;
   ЗаписьXML.ЗаписатьКонецЭлемента();
ЗаписьXML.Закрыть();

 

Для загрузки:

 //Загрузка объектов (справочников, документов) из файла xml используя сериализацию

ЧтениеХМЛ = Новый ЧтениеXML;
ЧтениеХМЛ.ОткрытьФайл(ИмяФайла); 
ЧтениеХМЛ.Прочитать();   // получили Root   

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

2) Перепровел документы, но не все записи регистров сведений формируются при проведении документов. 

Регистры сведений переносил через сериализацию таблицы значений.

В чем плюсы:

1) в копии выбрал данные из регистра запросом по определенному фильтру и результат выгрузил в таблицу значений (в примере тз), тз выгрузил в xml. 

Код для выгрузки:

//Выгрузка таблицы значений в xml используя сериализацию

ЗаписьXML = Новый ЗаписьXML;
ЗаписьXML.ОткрытьФайл(ИмяФайла);
СериализаторXDTO.ЗаписатьXML(ЗаписьXML,тз);
ЗаписьXML.Закрыть();

 

2) в базе получателе (напоминаю, что это наследник копии, из которой идет перенос данных, т.е. объекты по-умолчанию существуют) загрузил данные в таблицу значений. 

//Загрузка таблицы значений из xml используя сериализацию

ТекстовыйДокумент = Новый ТекстовыйДокумент;
ТекстовыйДокумент.Прочитать(ИмяФайла);               

ЧтениеXML = Новый ЧтениеXML;
ЧтениеXML.УстановитьСтроку(ТекстовыйДокумент.ПолучитьТекст());

ТипОбъектаXDTO = ФабрикаXDTO.Тип("http://v8.1c.ru/8.1/data/core","ValueTable");
ОбъектXDTO = ФабрикаXDTO.ПрочитатьXML(ЧтениеXML,ТипОбъектаXDTO);
ОбъектXDTO.Проверить();

ЧтениеXML.Закрыть();

тз = СериализаторXDTO.ПрочитатьXDTO(ОбъектXDTO);

 

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

Выгрузка/загрузка объектов базы данных в xml используя сериализацию таблицы значений

См. также

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 Оперативный учет 1С:Управление торговлей 10 Россия Управленческий учет Платные (руб)

Перенос данных из 1С:Управление торговлей 10.3 в 1С:Управление торговлей 11.5 с помощью правил обмена. Переносятся остатки, документы (обороты за период), справочная информация. Правила проверены на конфигурациях УТ 10.3 (10.3.88.x) и УТ 11.5 (11.5.21.x).

35000 руб.

23.07.2020    57480    266    75    

220

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Россия Платные (руб)

Правила в универсальном формате обмена для ERP 2.5, КА 2.5, УТ 11.5, БП 3.0, Розница, УНФ, для последних версий конфигураций. Ссылки на другие конфигурации в описании публикации. Правила совместимы со всеми другими версиями конфигураций новыми и старыми, поддерживающими обмен и синхронизацию в формате EnterpriseData. Не требуется синхронного обновления правил после обновления другой конфигурации, участвующей в обмене. Типовой обмен через планы обмена кнопкой Синхронизация вручную или автоматически по расписанию, или вручную обработкой.

27660 24894 руб.

12.06.2017    146865    863    300    

445

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

Перенос данных из 1С:Управление производственным предприятием 1.3 в 1С:Бухгалтерия предприятия 3.0 с помощью правил обмена. Переносятся остатки, документы (обороты за период), справочная информация. Правила проверены на конфигурациях УПП 1.3 (1.3.244.x) и БП 3.0 (3.0.172.x). Правила подходят для версии ПРОФ и КОРП.

35000 руб.

15.12.2021    26974    193    56    

147

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Россия Платные (руб)

Перенос данных из ERP в БП 3 | из КА 2 в БП 3 | из УТ 11 в БП 3 | из ЕРП в БП 3 | Сэкономьте время - используйте готовое решение для перехода! | Перенос разработан в формате КД 2 (правила конвертации данных) | Переносятся все возможные виды документов, начальных остатков и нормативно-справочная информация| Можно опционально выгружать каждую пару "номенклатура+характеристика" как отдельную номенклатуру | Есть выгрузка настроек счетов учета и зарплатных данных из ERP / КА 2 | Можно проверить на вашем сервере перед покупкой

55778 50200 руб.

15.04.2019    75079    201    156    

140

SALE! 10%

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Программист Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x Россия Бухгалтерский учет Управленческий учет Платные (руб)

Перенос данных из ERP в ЗУП 3 | из КА 2 в ЗУП | Готовые правила конвертации данных (КД 2) для переноса остатков, документов с движениями и справочной информации 3 | Есть перенос начальной задолженности по зарплате и начальной штатной расстановки на выбранную дату | Обороты за прошлые годы (данные для расчета среднего) переносятся свернуто в документ "Перенос данных" | Есть фильтр по организациям | Документы за текущий период переносятся сразу с движениями, поэтому не потребуется делать перерасчеты | Перенос можно проверить перед покупкой, обращайтесь!

53111 47800 руб.

03.12.2020    39026    111    71    

103

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист Платформа 1С v8.3 Платформа 1C v8.2 1С:Комплексная автоматизация 1.х 1С:Управление торговлей 10 1С:Управление производственным предприятием Россия Платные (руб)

Регулярный обмен, выгрузка, перенос из КА 1.1, УПП 1.3, УТ 10.3 для обмена с любыми конфигурациями, поддерживающими обмен в формате EnterpriseData (КД3) - БП 3.0, ERP, КА 2, УТ 11, Розница 2, УНФ 1.6 и другими. Правила для старых и доработанных конфигураций не требуют синхронного обновления и совместимы с новыми и будущими конфигурациями. Обмен по расписанию, через папку, FTP, почту.

16260 руб.

18.02.2016    189921    620    534    

538

Загрузка и выгрузка в Excel Логистика, склад и ТМЦ Ценообразование, анализ цен Файловый обмен (TXT, XML, DBF), FTP Бухгалтер Пользователь Платформа 1С v8.3 1С:Бухгалтерия 2.0 1С:Управление торговлей 10 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Платные (руб)

Эволюция не стоит на месте - новая удобная версия функциональной обработки для Вашего бизнеса! Что же Вы получаете? Удобный и интуитивно понятный интерфейс с 3-мя этапами работы. 2 режима - автоматический и ручной. Чтение XLSX, XLSM, CSV, XML/YML форматов без офиса, на любом сервере! Визуальное связывание колонок файла и реквизитов простым перетаскиванием колонок. Создание или обновление номенклатуры с иерархией, характеристик, доп. реквизитов, упаковок, загрузка практически неограниченного количества картинок на одну номенклатуру (с возможностью загрузки в несколько потоков одновременно), с хранением в томах или в базе. Загрузка номенклатуры поставщиков или поиск по их данным номенклатуры. Загрузка доп. реквизитов в характеристики. Загрузка штрихкодов с генерацией новых. Создание элементов справочников и ПВХ "на лету" для выбранных реквизитов. (Обновление от 22.04.2025, версия 9.10 - 10.0)

18000 руб.

20.11.2015    161209    398    386    

525
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. frkbvfnjh 811 24.01.23 15:08 Сейчас в теме
Спасибо, мне было полезно узнать про сериализацию ТЗ через XDTO.
2. frkbvfnjh 811 24.01.23 16:38 Сейчас в теме
А как узнали, что тип в XDTO должен называться "ValueTable"? Как мне узнать название того или иного типа 1С в XDTO?
3. andrey1508 110 25.01.23 23:25 Сейчас в теме
(2) в синтаксис помошнике в описании ТаблицаЗначений указано, что сериализуется через XDTO, указана область и имя типа XDTO.
4. frkbvfnjh 811 26.01.23 04:56 Сейчас в теме
(3) Да, действительно, есть в справке, никогда не обращал внимания. Спасибо!
5. frkbvfnjh 811 26.01.23 04:57 Сейчас в теме
Интересно, а нет метода с помощью которого можно было бы передать тип 1С, а в ответ получить строку имя типа XDTO...
6. andrey1508 110 28.01.23 11:46 Сейчас в теме
(5) не сталкивался с таким методом
7. JohnyDeath 302 28.01.23 13:27 Сейчас в теме
(5) а разве это разные строки? По-моему в типе XDTO всегда указано англ. наименование типа
8. lvictor58 138 13.02.23 17:20 Сейчас в теме
На инфострате есть обработка для лечения регистров сведений после обновления конфигурации когда происходит задваивание записей.
Выгрузка в файл происходит с использованием метода "Значение в файл" где в качестве значения берется выборка результата запроса.
А загрузка данных - через "Значение из файла". Приходилось пользоваться: все работает!
9. andrey1508 110 11.06.24 20:01 Сейчас в теме
Добавил небольшую обработку (пример) для выгрузки/загрузки регистра сведений через таблицу значений. Писал по-случаю, переносил регистр "Штрихкоды" Розницы 2.3. В принципе шаблон подойдет для переноса любого регистра в дочернюю базу или для восстановления из копии. Измените запрос и имя файла и вперед.
10. andrey1508 110 10.07.24 17:13 Сейчас в теме
Удалил обработку, чтобы не вводить в заблуждение читателей (ждали штрих кодов, а там перенос регистра сведений через таблицу значений).
11. It-developer 26 08.04.25 16:33 Сейчас в теме
п. 1 помог. Спасибо. Просто и понятно
Оставьте свое сообщение