Из 1с 7.7 в формате xml. Внешний вид и особенности использования универсального обмена данными

Из 1с 7.7 в формате xml. Внешний вид и особенности использования универсального обмена данными

Перенос данных состоит из двух этапов:

1-й - выгрузка данных из ТиС в файл формата xml с помощью обработки «ОбработкаВыгрузкиСправочников. ert » .

ПОДРОБНАЯ ИНСТРУКЦИЯ:

1) Открываем обработку «ОбработкаВыгрузкиСправочников. ert » в 1С 7.7 ТиС 9.2

Рис.1 Основной вид обработки выгрузки.

2) Выбираем путь к правилам обмена (п.1) к файлу «ПОД_Перенос_Справочников_ТиС_БП20.xml ».

3) Сразу можно указать файл для выгрузки данных в формате xml в (п.2) .

4) Если будут выгружаться документы, необходимо указать период выгрузки данных в (п.3).

5) Далее нажимаем кнопку (п.11), появится список Правил выгрузки данных. Слева каждого правила флажком можно отключать или подключать выгружаемый объект. Например, если нас интересует только справочник контрагенты пометка должна быть включена только у правила Контрагенты .

6)Если нам необходимо задать какой-либо отбор для объекта выгрузки (на рис.1 это Организации (п.10)). Выбираемэтот объект, нажимаем кнопку Установить ПВД (в (п.12) появится название выбранного объекта «Отбор данных для Организации ») только после этого можно будет добавлять условие для отбора кнопка Условие отбора (п.5) . В (п.6) ставим отметку если это условие отбора будет задействовано, далее (п.7) выбираем реквизит по которому будет делаться отбор. (П.8) задается логическая операция для отбора. И в (п.9) задается само значение отбора. После того как будет установлено условие отбора для какого-либо правила, в списке правил выгрузки данных (п.10) у этого правила в квадратных скобках появится слово [ОТБОР].

7) Приведу пример для выгрузки справочника Контрагенты. И так, нам необходимо выгрузить контрагентов только из группы «Покупатели» рис. 2

Выбираем объект Контрагенты в списке правил, жмем кнопку Установить ПВД, далее жмем кнопку Добавить условие, в таблице отбора появиться новая пустая строка заполняем ее: двойным кликом в колонке «Реквизит отбора» в новой строке (п.2) вызовем окно выбора реквизита отбора (таблица реквизитов объекта по которым возможно сделать отбор), в таблице (п.1) выбираем реквизит Родитель .

Рис.2 Выбор реквизита отбора

Следующий шаг рис. 4 выбор логического оператора в (п.1) из списка операторов (п.2), в нашем случае «В», т.е. будут отобраны и выгружены только те элементы которые входят в группу «ПОКУПАТЕЛИ»

Условий на одно правило может быть сколько угодно, все они будут сочетаться через логическую операцию «И».

1) Все теперь нажимаем кнопку Выгрузить , ждем когда пройдет выгрузка выбранных объектов. По окончанию получим радостное сообщение рис. 5.

Рис. 5

1) Переходим ко второму этапу - Загрузка в БП 2.0. Открываем стандартную обработку в «Бухгалтерии предприятия» - главное меню «Сервис» => «Прочие обмены данными» => «Универсальный обмен данными в формате XML» рис. 6 (п.1).

1) В открывшейся форме Рис. 7 на вкладке в поле Имя файла для загрузки (п.2) указываем файл, в который была произведена выгрузка, жмём кнопку Загрузить данные (п.1). По завершению загрузки появится окошко с надписью «Загрузка завершена».

Рис. 7 Типовая обработка универсального обмена в БП 2.0

Ну вот и всё.)

Надеюсь эта статья кому-нибудь пригодиться и поможет. Если кому очень надо можно будет доработать и под нетиповые конфигурации, обращайтесь, пишите комментарии.

почта: [email protected].

Здесь я опишу основные моменты при работе со стандартной компонентой v7plus.dll . Информация сильно устаревшая, и появилась она здесь больше для меня самого — чтобы не забыть, когда в следующий раз появится. Описывается чтение из XML-файла средствами XML-парсера почти стандартной компоненты. Примером послужит файл документа-заявки, выгруженного в файл в формате CommerceML 2.03 (с сайта на Битриксе).

Итак, начинаем. Первым делом нужно загрузить компоненту. Вот типичный код:

Если + "v7plus.dll") <> 1 Тогда Если ЗагрузитьВнешнююКомпоненту(КаталогИБ() + "ExtForms\" + "v7plus.dll") <> 1 Тогда Если ЗагрузитьВнешнююКомпоненту(КаталогПрограммы() + "v7plus.dll") <> 1 Тогда Предупреждение("Компонента v7plus.dll не найдена!"); Возврат; КонецЕсли; КонецЕсли; КонецЕсли; Анализатор = СоздатьОбъект("AddIn.XMLParser");

Анализатор умеет работать со схемами, но этот момент я рассматривать не буду. Простое линейное (ну или почти линейное) чтение файла. Поэтому просто создаём новый документ:

XML_Документ = Анализатор . СоздатьДокумент (); Если ПустоеЗначение(XML_Документ ) = 1 Тогда Возврат КонецЕсли; XML_Документ . Загрузить (ИмяФайла );

В переменной ИмяФайла записана строка с именем открываемого файла. После этого можно читать файл, постепенно расшифровывая его.
Файл XML состоит из узлов и атрибутов. Каждый узел может содержать ноль и более атрибутов и ноль и более дочерних узлов. Корневой узел можно получить прямо из переменной XML_Документ . Для наглядности рассмотрим часть XML-файла:

<КоммерческаяИнформация ВерсияСхемы=»2.03″ ДатаФормирования=»2014-04-09 14:25″>
<Документ>
<Ид>53006
<Номер>53006
<Дата>2014-04-29
<ХозОперация>Заказ товара
<Роль>Продавец
<Валюта>руб
<Курс>1
<Сумма>300000.00
<Контрагенты>…
<Время>11:52
<Комментарий>ТЕСТ…….БСВ
<Товары>
<Товар>
<Ид>ID46
<Наименование>…
<БазоваяЕдиница Код=»796″ НаименованиеПолное=»Штука» МеждународноеСокращение=»PCE»>шт

Здесь приведена сильно сокращённая версия файла, точнее, его часть. Цель этой статьи — не описать формат CommerceML, а показать работу с XML-файлом, поэтому приведу только команды. Файл CommerceML состоит из корневого узла «КоммерческаяИнформация «. Его мы считаем из документа:

ЭлДокумент = XML_Документ . ВыбратьУзел ("КоммерческаяИнформация");

Значением переменной ЭлДокумент будет узел (OLE-объект). У него есть дочерние узлы и атрибуты. В одном файле может быть несколько документов, поэтому перебираем их в цикле:

Выборка = ЭлДокумент . ВыбратьУзлы ("Документ"); Для й = 1 По Выборка . КоличествоУзлов Цикл Док = Выборка . ПолучитьУзел (й - 1);

Свойство КоличествоУзлов возвращает общее число дочерних узлов, а метод ПолучитьУзел() возвращает указанный дочерний узел (нумерация идёт с 0).

Узел «Номер » не имеет ни атрибутов, ни дочерних узлов. Он имеет только значение «00006 «. Аналогично «Дата «, «ХозОперация » и многие другие. Для получения значения узла используется следующая конструкция:

Номер = Док . ВыбратьУзел ("Номер"). Значение ; НомерЧисло = Число(Док .ВыбратьУзел ("Номер"). Значение );

Здесь используется метод ВыбратьУзел() . В отличие от «ВыбратьУзлы() «, он возвращает не список, а самый первый узел с указанным именем. А его свойство «Значение » возвращает строку со значением. Для преобразования значения к нужному типу воспользуемся функциями преобразования. Дату придётся преобразовывать частями (она в XML хранится в виде гггг-мм-дд, не поддерживаемом стандартной функцией Дата()). Возможно, что при использовании схем преобразование типов будет выполняться автоматически — не проверял.
Для чтения атрибутов служит следующий метод:

ОКЕИ = Товар . ВыбратьУзел ("БазоваяЕдиница"). ПолучитьАтрибут ("Код");

Здесь Товар — это узел «Товар «. Значение атрибута, как и единичного дочернего узла, можно получить по имени атрибута. Возвращается всегда строка, поэтому при необходимости надо привести тип значения к требуемому. Если у узла понадобится считать несколько атрибутов, лучше сохранить значение узла в отдельной перменной.
Ну вот и все основные функции, необходимые для полноценного чтения XML-файлов.

Работа с файлами XML из 1С:Бухгалтерии 7.7

С версии 1С 7.7 универсальная загрузка из XML (как и любые процессы обмена) происходит при помощи встроенного механизма "Конвертация данных". В разных его версиях реализованы различные подходы к организации обменных процессов.

Универсальная обработка

С седьмой версии 1С обмениваться информацией между базами и платформами можно при помощи встроенного инструмента "Конвертация данных". Его средства дают возможность преобразовывать информацию из баз 1С в формат XML и переносить ее из седьмой версии в восьмую, из "Управления торговлей" в "Склад" и др. Для 1С 7 этот инструмент включает в себя следующие компоненты:

    База конфигурации;

    Внешние обработки:

    • V77Exp.ert выгрузка из 1С в XML;

      MD77Exp.ert выгружает в XML-файл метаданные.

Конфигурация и обработки доступны на официальном сайте 1С для всех пользователей (партнеров) продукции этой компании. Их же можно найти на диске ИТС, который прилагается к любому продукту 1С при покупке.

Подходы к загрузке данных в XML-формат

Для переноса информации в рамках 1С используются версии 2.0 и 3.0 "Конвертация данных". Их различие заключается в подходах к обработке и преобразованию данных.

1.В версии 2.0 для переноса данных требуется создать правила. Они основываются на метаданных базы-источника и принимающей базы, включая описания объектов всех имеющихся типов. Правила заносятся в отдельный документ. Чтение этого файла производится при каждой выгрузке. Если описание баз изменяется, тогда правила следует перепроверять и обновлять.

2.Версия 3.0 "Конвертации данных" разрабатывалась с целью обособления процессов обмена от структуры информационных баз. Это стало возможным благодаря XML-формату - EnterpriseData. Теперь для каждой базы создаются правила преобразования ее содержимого в этот универсальный формат без необходимости создания правил для каждой конкретной пары "источник-приемник" заново.

Для помощи с установкой конфигурации и отладке обмена данными обращайтесь в компанию «Сетби». Мы не просто подберем инструменты под конкретные задачи и настроим их работу, но и сэкономим ваши нервы и время.