Коротко про XML

16.03.12

Разработка - Математика и алгоритмы

Это даже не статья, а заметки по поводу. Для тех, кто совсем не разбирался с XML, может помочь начать. Попытался изложить самое основное про выгрузку-загрузку объектов...

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

  1. При написании XML-выгрузки  нужно думать о том, каким образом  должны загружаться данные.  
  2. Простейшая  выгрузка, которая выгружает документ,  выглядит примерно так:
    Объект = ВыгружаемыйДокумент. ПолучитьОбъект();
    ЗаписьXML = Новый ЗаписьXML;
    ЗаписьXML.ОткрытьФайл(Путь + "doc_xml.xml");
    ЗаписьXML.ЗаписатьОбъявлениеXML();
    ЗаписьXML.ЗаписатьНачалоЭлемента("Root");   
    ЗаписьXML.ЗаписатьНачалоЭлемента("ДокументРеализацияТоваровУслуг");  
    ЗаписатьXML(ЗаписьXML,Объект, НазначениеТипаXML.Явное);       
    ЗаписьXML.ЗаписатьКонецЭлемента(); //ДокументРеализацияТоваровУслуг              
    ЗаписьXML.ЗаписатьКонецЭлемента(); //Root
    ЗаписьXML.Закрыть();

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

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

    ЗаписьXML = Новый ЗаписьXML;
    ЗаписьXML.ОткрытьФайл(Путь + "doc_xml.xml");
    ЗаписьXML.ЗаписатьОбъявлениеXML();
    ЗаписьXML.ЗаписатьНачалоЭлемента("Root");

    //!!!!!!
    ЗаписьXML.ЗаписатьНачалоЭлемента("СправочникКонтрагенты");
    Контрагент = Объект.Контрагент.ПолучитьОбъект();
    ЗаписатьXML(ЗаписьXML,Контрагент, НазначениеТипаXML.Явное);
    ЗаписьXML.ЗаписатьКонецЭлемента(); //СправочникКонтрагенты
    //!!!!!!

    ЗаписьXML.ЗаписатьНачалоЭлемента("ДокументРеализацияТоваровУслуг");               
    ЗаписатьXML(ЗаписьXML,Объект, НазначениеТипаXML.Явное); 
    ЗаписьXML.ЗаписатьКонецЭлемента(); //ДокументРеализацияТоваровУслуг          
    ЗаписьXML.ЗаписатьКонецЭлемента(); //Root
    ЗаписьXML.Закрыть();

 

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

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

 

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

 

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

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

    Файл = Новый ЧтениеXML;
    Файл.ОткрытьФайл(Путь + "doc_xml.xml");
    // Позиционируемся на начале элемента, содержащего документ

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

                Объект.Записать();
            Исключение
                Сообщить(" не могуууу: " + Строка(Объект));                                                                                                                              КонецПопытки;
            КонецПопытки;
            Сообщить(Строка(Объект));
        КонецЕсли; 
    КонецЦикла;

    Файл.Закрыть();

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

См. также

SALE! 15%

[ED3] Обмен для ERP 2.5, КА 2.5, УТ 11.5 БП 3.0, Розница, УНФ и других с EnterpriseData (универсальный формат обмена), правила обмена

Обмен между базами 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. Не требуется синхронного обновления правил после обновления другой конфигурации, участвующей в обмене. Типовой обмен через планы обмена кнопкой Синхронизация вручную или автоматически по расписанию, или вручную обработкой.

25080 22572 руб.

12.06.2017    134931    722    291    

388

SALE! 20%

Перенос данных из ERP 2 / КА 2 / УТ 11 в БП 3.0. Переносятся документы, начальные остатки и справочники

Обмен между базами 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 | В продаже с 2019г. | Воспользовались более 176 предприятий! | Сэкономьте время - используйте готовое решение для перехода! | Перенос разработан в формате КД 2 (правила конвертации данных) | Переносятся все возможные виды документов, начальных остатков и нормативно-справочная информация| Можно опционально выгружать каждую пару "номенклатура+характеристика" как отдельную номенклатуру | Есть выгрузка настроек счетов учета и зарплатных данных из ERP / КА 2 | Можно проверить на вашем сервере перед покупкой, обращайтесь!

34650 27720 руб.

15.04.2019    68416    178    138    

111

SALE! 20%

Перенос данных из ERP 2 / КА 2 в ЗУП 3. Переносятся остатки, документы и справочники

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

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

43450 34760 руб.

03.12.2020    34168    80    58    

78

SALE! 10%

Перенос данных из УТ 10.3 в УТ 11.5. Переносятся документы (обороты за период), справочная информация и остатки

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

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

28000 25200 руб.

23.07.2020    46289    196    64    

158

Перенос данных из Парус 10 в ЗГУ ред.3

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

Обработка позволяет перенести кадровую информацию и данные по заработной плате, фактических удержаниях, НДФЛ, вычетах, страховых взносах из базы Парус 10 учреждений в конфигурацию 1С:Зарплата и кадры государственного учреждения ред. 3 (ЗГУ) и начать с ней работать с любого месяца года.

60000 руб.

05.10.2022    9207    9    8    

10

SALE! 10%

Перенос данных из УПП 1.3 в БП 3.0. Переносятся документы (обороты за период), справочная информация и остатки

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

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

28000 25200 руб.

15.12.2021    20244    132    38    

90

SALE! 10%

Перенос данных из БП 3.0 в УНФ 3.0 / УНФ 1.6. Переносятся остатки, документы и справочная информация

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

В продаже с 2018г. | Воспользовались более 41 предприятия! | Правила конвертации (КД 2) для переноса данных из БП 3 в УНФ | Переносятся все виды документов, начальные остатки и вся возможная справочная информация | Есть фильтр по организациям | Оперативно обновляем на новые релизы | Оказываем техподдержку | В комплект файлов входит инструкция, авторская версия обработки "Универсальный обмен...", актуальные правила переноса данных и архив старых версий переноса | Учет в БП 3 должен быть корректным, некорректные данные не переносятся | Можно бесплатно проверить на вашем сервере до покупки!

50722 45650 руб.

10.07.2018    67442    41    122    

46

Загрузка номенклатуры c картинками (несколько потоков одновременно) и сопутствующими данными в базу и любые документы из yml, xls, xlsx, xlsm, ods, ots, csv для УТ 10.3, УТ 11 (все), БП 3, КА 2, ERP 2, УНФ 1.6/3.0, Розница 2

Загрузка и выгрузка в 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 Платные (руб)

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

13200 руб.

20.11.2015    150712    367    375    

501
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. daho 8 22.03.12 07:12 Сейчас в теме
Спасибо, начнем... давно искал что-то подобное
2. mnikol 22.03.12 16:03 Сейчас в теме
Полезная информация. Спасибо.
3. awk 741 23.03.12 00:01 Сейчас в теме
(0)Жуть, а не статья.
1. Оформи нормально (в едином стиле).
2.
1)При написании XML-выгрузки нужно думать о том, каким образом должны загружаться данные.
Скорее 1С предусматривает стратегию обмена данными: "Выгрузка в формате приемника". Есть другая стратегия: "Выгрузка как есть." - Разбор XML проблема принимающей стороны.
3. Простейшая выгрузка:

Запись = Новый ЗаписьXML();
Запись.ОткрытьФайл(Путь + "doc_xml.xml");
ЗаписатьXML(Запись, Объект);
Запись.Закрыть();


Эта выгрузка подойдет только при идентичных базах. Если базы различны, то придется поплясать с бубном (СериализаторXDTO).

Только в этом случае, получится простейший код загрузки:
Чтение = Новый ЧтениеXML;
Чтение.ПерейтиКСодержимому();
Объект = ПрочитатьXML(Чтение);
Объект.Записать();


4.
Другими словами, когда будет происходить загрузка нашей реализации, то если не будет в базе-приемнике, скажем, номенклатуры с уникальным идентификатором, который совпадает с уникальным идентификатором номенклатуры из базы-источника, то вместо номенклатуры будет значение ( или как-то так :) ).
Если не будет в базе объекта на который мы ссылаемся, то будет "Объект не найден". При загрузке этого объекта или тестирования и исправления, с выбором "создавать объекты" - отсутствующие объекты будут созданы.
hazyaka; bionicle; fuxic; +3 Ответить
4. dumal 25.03.12 20:11 Сейчас в теме
Спасибо Вам. Такую бы заметочку хотя бы лет пять назад прочитать. Так ведь нет. Сейчас уже неактуально, но начинающим, наверное, поможет
5. ia57 2 27.04.12 14:25 Сейчас в теме
Спасибо. Немного посветлело.
Оставьте свое сообщение