Записки программиста 1с

1с загрузка данных xml

загрузка данных объектов между конфигурациями 1с через xml

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

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

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

    Все базы данных поддерживают стандарт формата в полном объеме. Существует множество вариантов, в которых применяют XML для переноса данных. все они реализованы в 1С и совместимых с ней продуктах.

      Часто формат XML используются для решения следующих вопросов:

     ·Выгрузка прайс-листов, заказов, печатных форм документов.

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

     ·Обмен данными с банками, налоговой службой, внебюджетными фондами.

          В программах 1С существует типовая обработка загрузки данных из файла формата XML.

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

В меню «Функции для технического специалиста» перейти в пункт «Обработки» и в предложенном списке выбрать «Универсальный обмен данными в формате XML».

1с загрузка данных xml
Универсальный обмен данными в формате XML

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

Выгрузка данных элементов справочника 1с в файл XML

Процедура ВыгрузитьОбъектыВXML(Кнопка)

ЗаписьXML = Новый ЗаписьXML();
ЗаписьXML.ОткрытьФайл("c:\obmen.xml");
ЗаписьXML.ЗаписатьНачалоЭлемента("Spravohniki");
ЗаписьXML.ЗаписатьНачалоЭлемента("Валюты");

Запрос = Новый Запрос;
Запрос.Текст = "ВЫБРАТЬ
|	Валюты.Ссылка
|ИЗ
|	Справочник.Валюты КАК Валюты";

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

По такому же принципу можно выгружать и документы. Причем можно выгрузить один объект, для этого нужно передать вторым параметром метода “ЗаписатьXML” необходимый объект.

В итоге при выполнении этой процедуры сформируется файл со следующим содержанием:

Текст XML файла


<Spravohniki>
<Валюты>
<CatalogObject.Валюты>
<Ref>bd72d8f9-55bc-11d9-848a-00112f43529a</Ref>
<DeletionMark>false</DeletionMark>
<Code>643</Code>
<Description>руб.</Description>
<НаименованиеПолное>Российский рубль</НаименованиеПолное>
<ПараметрыПрописиНаРусском>рубль, рубля, рублей, м, копейка, копейки, копеек, ж, 2</ПараметрыПрописиНаРусском>
</CatalogObject.Валюты>
<CatalogObject.Валюты>
<Ref>bd72d8fa-55bc-11d9-848a-00112f43529a</Ref>
<DeletionMark>false</DeletionMark>
<Code>840</Code>
<Description>USD</Description>
<НаименованиеПолное>Доллар США</НаименованиеПолное>
<ПараметрыПрописиНаРусском>доллар, доллара, долларов, м, цент, цента, центов, м, 2</ПараметрыПрописиНаРусском>
</CatalogObject.Валюты>
<CatalogObject.Валюты>
<Ref>cbcf4923-55bc-11d9-848a-00112f43529a</Ref>
<DeletionMark>false</DeletionMark>
<Code>978</Code>
<Description>EUR</Description>
<НаименованиеПолное>ЕВРО</НаименованиеПолное>
<ПараметрыПрописиНаРусском>евро, евро, евро, м, цент, цента, центов, м, 2</ПараметрыПрописиНаРусском>
</CatalogObject.Валюты>
<CatalogObject.Валюты>
<Ref>0e617614-55bd-11d9-848a-00112f43529a</Ref>
<DeletionMark>false</DeletionMark>
<Code>792</Code>
<Description>TRL</Description>
<НаименованиеПолное>Турецкая лира</НаименованиеПолное>
<ПараметрыПрописиНаРусском/>
</CatalogObject.Валюты>
<CatalogObject.Валюты>
<Ref>0e617615-55bd-11d9-848a-00112f43529a</Ref>
<DeletionMark>false</DeletionMark>
<Code>001</Code>
<Description>у.е.</Description>
<НаименованиеПолное>Условная единица</НаименованиеПолное>
<ПараметрыПрописиНаРусском>условная единица, условные единицы, условных единиц, ж, цент, цента, центов, м, 2</ПараметрыПрописиНаРусском>
</CatalogObject.Валюты>
</Валюты>
</Spravohniki>

Корень ХМЛ-файла “Spravohniki” и ветка “Валюты” сделаны для пояснения содержимого XML файла, можно обойтись без них. Но в файле обязательно должен быть корень дерева, т.е. перед записью данных нужно обязательно написать “ЗаписатьНачалоЭлемента”.

Загрузка объектов из XML


Процедура ЗагрузитьОбъектыИзXML(Кнопка)
	
ЧтениеXML = Новый ЧтениеXML();
ЧтениеXML.ОткрытьФайл("c:\obmen.xml");
	
Пока ЧтениеXML.Прочитать() Цикл
    Пока ВозможностьЧтенияXML(ЧтениеXML) Цикл 
	ТекущийОбъект = ПрочитатьXML(ЧтениеXML);
	ТекущийОбъект.Записать();
  КонецЦикла;	
КонецЦикла;	
ЧтениеXML.Закрыть();  

КонецПроцедуры

Как Вы видите программа сама определяет тип объекта и все его свойства методом “ПрочитатьXML”. Здесь только стоит упомянуть, что при загрузке программа ищет наличие этого объекта по Уникальному идентификатору. поэтому если у Вас уже есть такой объект, то программа перезапишет его заменив данными из файла. И наоборот при попытке загрузить объект с другим идентификатором, но такими же данными программа сообщить, что объект с таким кодом(номером) уже существует.

Рассмотрели перенос данных 1с между конфигурациями Предприятие 8.

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *