Выгрузка объекта в xml средствами 1C

  1. При написании XML-выгрузки  нужно думать о том, каким образом  должны загружаться данные.
  2. Простейшая  выгрузка, которая выгружает документ,  выглядит примерно так:

    В данном случае, выгружаются все атрибуты документа. Если атрибут имеет ссылочный тип, то “доминирующим” аспектом в выгрузке такого атрибута будет служить уникальный идентификатор. Другими словами, когда будет происходить загрузка нашей реализации, то если не будет в базе-приемнике, скажем, номенклатуры  с  уникальным идентификатором, который совпадает с уникальным идентификатором номенклатуры из базы-источника, то вместо номенклатуры будет значение (  или как-то так 🙂  ). На момент загрузки нашей реализации, все атрибуты ссылочного типа уже должны быть загружены в базу.

    1. “Продвинутый” вариант выгрузки предполагает, что помимо основного объекта (в нашем примере Документ.РеализацияТоваровУслуг) выгружаются еще и объекты, являющиеся атрибутами ссылочного типа. В нижеследующем примере выгружается  еще и Контрагент из шапки документа.

  3. Теперь,  когда мы будем загружать в информационную базу-приемник нашу реализацию, то сможем создать или изменить объект  типа “Контрагент”.

    Очевидно, что у объекта ссылочного типа могут быть свои атрибуты ссылочного типа, а у тех – свои. Таким образом, если мы хотим выгрузить ссылочный объект “полностью”, то должны построить дерево выгрузки, например, при помощи рекурсии.

     

     Загрузка объекта в xml средствами 1C 

     

    1) Должен быть подготовленный файл с выгруженными данными, из которого, собственно и произойдет выгрузка

    2) Простейший вариант загрузки выглядит следующим образом:


  4. Цикл Файл.Прочитать ()… позволяет пройтись по всем ветвям  XML-графа и создать объекты,  атрибуты которых определяются “листьями” этих ветвей. В нашем примере, в том случае, если ветвь  соответствует Контрагенту, то головному контрагенту присваивается пустая ссылка.