Использование XML-схемы из макета внешней обработки

28.10.19

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

Простой способ использования XML-схем из макета внешней обработки.

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

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

В публикации описан простой пример создания и использования XML-схемы из макета внешней обработки.

 

Если изначально у нас есть только XML-файл, необходимо получить из него XML-схему. Сделать это можно с помощью любого онлайн-конвертера «XML to XSD».

Исходный XML-файл:

Полученная XML-схема:

В сформированную схему добавляем пространство имен (уникальная строка-идентификатор схемы).  В нашем случае, пусть будет «http://SchemeTEST».

Далее во внешней обработке создаем макет с типом Текстовый документ и добавляем в него XML-схему.

Чтобы использовать добавленную схему, пишем следующий код:

Последовательность действий такая:

  1. В каталоге временных файлов создаем новый файл
  2. Получаем макет со схемой
  3. Записываем схему в созданный файл
  4. Создаем Фабрику XDTO.  При создании фабрики, передаем путь к созданному файлу, который уже содержит 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    134933    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    68417    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    34169    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    46290    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    20247    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    67445    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    150715    367    375    

501
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. vadver 39 28.10.19 20:21 Сейчас в теме
Очень интересно, каким образом у вас сочетается в заголовке XML "encoding="utf-8" и в коде
ТекстДок.Прочитать(ИмяВременногоФайла, "cp866")?

Это первое.
На закуску - ну научитесь теги "CODE" применять для оформления кода - вроде не сложно же
2. Milanick 28.10.19 22:14 Сейчас в теме
А какое практическое применение данного функционала?
3. dusha0020 1103 29.10.19 11:47 Сейчас в теме
(2)
А какое практическое применение данного функционала?

Например когда схемы сервиса нет, а есть только инструкция по формированию запросов и образцы XML, которые Вы получаете в ответ на запросы. Тогда приводите XML ответы к XSD схемам, сохраняете их в макеты, пишите тонну кода и вот этой бородой в обработке заменяете стандартную WS ссылку.
Такой корявый подход к работе с клиентами, например, практикует французский маркетплейс CDiscount. Из моего опыта.
Можно, конечно, закачать схемы в XDTO пакеты конфигурации, но это мне не сильно нравится для работы с побочными и редко используемыми сервисами, да и разработка и отладка сервиса во внешней обработке намного проще.
d4rkmesa; PLAstic; +2 Ответить
4. capitan 2466 29.10.19 11:51 Сейчас в теме
Прекрасно.
Почему текстовый документ, когда схему можно сразу положить в макет как двоичные данные ?
5. Cерый 25 30.10.19 09:59 Сейчас в теме
В макеты удобно ложить все: дополнительные обработки, файлы правил обмена, файлы запросов:
ПолучитьМакет(ИмяМакета).Записать(ИмяФайла);
по аналогии с работой стандартного справочника ВнешниеОбработки
6. capitan 2466 30.10.19 14:24 Сейчас в теме
(5)Ложить может быть удобно и все, если не прибьют граммар-наци.
Но для каждого вида данных есть свой тип хранения.
В данном случае - этой выигрыш в скорости
8. Cерый 25 30.10.19 16:00 Сейчас в теме
Благодарю Вас за ответ, файловые операции могут быть сомнительны как в плане производительности, так и в плане качества кода,
в свое время пытался переписать типовой справочник ВнешниеОбработки для их исключения.
По крайней мере в макетах можно хранить тексты запросов:
Запрос.Текст=ПолучитьМакет("Макет").ПолучитьТекст()
без обрамлений 124-ми символами(|) типа:
|ВЫБРАТЬ
| Превдоним.Реквизит
и дальнейших игр с ними ...
(6)
7. PLAstic 295 30.10.19 14:37 Сейчас в теме
Спасибо, почерпнул пару новых моментов для себя. Как минимум, пригодится в высоконагруженных системах, остановка которых нежелательна.
9. UberElder 01.11.19 13:25 Сейчас в теме
Довольно интересный способ чтения из XML, возьму на заметку)
Olesia_Matusevich; +1 Ответить
10. da_1c 181 03.11.19 17:35 Сейчас в теме
Можно без временных файлов, например так
	
        СтрокаXML = ЭтотОбъект.ПолучитьМакет("SchemaXSD").ПолучитьТекст();
	ЧтениеXML = Новый ЧтениеXML;	
	ЧтениеXML.УстановитьСтроку(СтрокаXML);
	Построитель = Новый ПостроительDOM;
	Документ = Построитель.Прочитать(ЧтениеXML);
	ПостроительСхемы = Новый ПостроительСхемXML;
	Схема = ПостроительСхемы.СоздатьСхемуXML(Документ.ЭлементДокумента);	
	НаборСхем = Новый НаборСхемXML;
	НаборСхем.Добавить(Схема);
	СвояФабрикаXDTO = Новый ФабрикаXDTO(НаборСхем);
Показать
keyn5565`; user1995904; Sarkikker; user1852707; janit; eeeio; desarz; agdam_m; d4rkmesa; ksergeya; ZeroSumGame; dusha0020; IgorS; +13 Ответить
Оставьте свое сообщение