[Инфостарт] Разбор XML документа - почти все возможные способы слив скачать
- Добавлено: 2025-02-12
- Сайт автора: Перейти
- Доступ: Облако Mail / Yandex / Google
- Скачать: PC / Smartphone / Tablet
К вам пришел XML документ, как получить из него данные для обработки в 1С. ЧтениеXML, ДокументDOM, XPath, ФабрикаXDTO, ПакетыXDTO в сравнении.
При обмене данными, как бы он не производился ( через файлы, через HTTP запросы или еще каким либо другим путем ) все равно основным форматом обмена является XML. В 1С существует несколько способов обработки XML документов – какой из них выбрать по критерию логической простоты и быстродействия? Для практической проверки различных методов был создан XML документ вида.
Задачей всех проверяемых методов было получение из XML файла массива, состоящего из структур со свойствами Номер, Дата, Поставщик, Состав, причем свойство Состав само является массивом структур со свойствами Номенклатура и Количество.
Первый метод – простое последовательное чтение XML.
Текущее положение в XML документе отслеживается в переменной ТекущийПуть и при поступлении текстового узла на основании этой переменной заполняются (или игнорируются) соответствующие данные 1С. Конечно, не совсем корректно оценивать логическую сложность программы в строках исходного текста, но тем не менее это самый большой объем из всех методов - 64 строки. Что касается быстродействия (оно проверялось на компьютере памятью в 8 Гб и процессором Intel i7 2.2 Ггц, было создано два файла один на 10 тысяч записей объемом 10 мегабайт, другой на 100 тысяч и 100 мегабайт соответственно) , то на файле 10 000 записей полная обработка заняла 30 секунд и на файле в 100 мегабайт линейно увеличилась в 10 раз.
Второй метод – получение из XML файла документа DOM и последовательный перебор всех узлов полученного документа
Логически этот метод весьма незначительно проще прямого ЧтенияXML (57 строк кода против 62), а вот с быстродействие картина интересная: для файла в 10 тысяч записей быстродействие составило 12 секунд (быстрее более чем в два раза) , но для файла со 100 тысячами записей резко поднялась до 1000 секунд (медленнее более чем в три раза).
Третий метод подобен второму, но вместо последовательного перебора узлов применен отбор требуемых узлов в DOM документе с помощью выражений XPath .
Этот метод немного проще чем простой перебор узлов в DOM документе, но быстродействие … При 10 000 записей 69 секунд , а для 100 000 обработка длилась более часа, так и не завершилась, после чего была снята принудительно.
Очевидно метод с использованием DOM, в особенности при поиске узлов документа XPath выражениями, надо использовать только для небольших изменений DOM документа со сложной структурой узлов.
Все последующие методы используют для разбора XML документа фабрику XDTO.
Четвертый метод использует метод ПрочитатьXML глобальной ФабрикиXDTO. При этом тип получаемого объекта не указывается, его определяет сам метод фабрики. Тут есть маленькая тонкость – в случае, если тип получаемого объектаXDTO не указан, фабрика не всегда может самостоятельно определить что она получила одиночный объект или список из нескольких одинаковых объектов ( в нашем примере если ПриходныйОрдер в XML документе будет один фабрика посчитает что ПриходыXDTO.ПриходныйОрдер это одиночный объект а не список).
Данный метод не только заметно проще, чем все предыдущие, но и показывает отличное быстродействие на 10 000 записях 4,6 секунды, а при 100 000 обработка длится 46 секунд. Что показывает линейную зависимость от объема обрабатываемого файла.
Пятый метод схож с предыдущим, но глобальной фабрике XDTO подается на вход не только сам XML документ, но и его тип. Этот тип берется из ветки конфигурации XDTO-пакеты. (Если те кто передает вам XML данные хорошие люди, то они должны передать вам и XML схему данных – файл с расширением .xsd из которого вы и создаете в своей конфигурации XDTO-пакет – команда импорт XML схемы …, если нет требуемый пакет обычно не сложно создать вручную, анализируя переданные XML данные).
Один нюанс – частенько XML данные передают без указания URI пространства имен ( атрибут xmlns). Если это так, то необходимо самому добавить недостающий атрибут в XML данные, что и делают первые три оператора процедуры.
Метод замечательный, как по простоте создания, так и по быстродействию – 3,1 секунды на 10 000 записях.
И последний метод. Это скорее некоторая модификация пятого метода, но для условия, что не используется объект конфигурации XDTO-пакет, и фабрика XDTO создается на ходу из текстового описания XML схемы. (Примечание 1-Конечно можно загнать схему в текстовый макет, и оттуда уже использовать, но для учебной программы так нагляднее. 2-Текстовый вариант XML схемы можно например получить создав XDTO-пакет в любой конфигурации XDTO-пакет и выполнив команду Экспорт XML схемы..)
В прилагаемой конфигурации (.cf) все методы разбора XML представлены в общей команде РазобратьXML, там же в другой общей команде СоздатьXML представлены средства для создания тестовых данных.
Описание с сайта:
ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, «строительные материалы» для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.
Формат выдачи: файл конфигурации .cf
Рекомендуемые курсы
WEB-обучение Основной упор в программе данного курса сделан на следующие возможности: Ознакомление с возможностью организации обмена между конфигурациями «1С:Предприятие» по правилам XML с использованием 1С:Конвертация данных 3.1 (ранее технология «Конвертация данных 2.1»). Слушатели приобретут
Курс целиком посвященный одной из важнейших тем - решению оперативных задач Материалы состоят из записей вебинаров последнего набора курса. Основная цель курса: Сформировать у слушателей практические навыки, связанные с разработкой прикладных решений, работающих на платформе «1С:Предприятие» и
1)Решения всех основных билетов для подготовки к Специалист ЗУП 2)1С: Специалист ЗУП 8. Решение 6 билетов экзамена по 1С: Зарплата и Управление Персоналом 3.1 3)Экзамен 1С:Специалист-Консультант УНФ. Полные и правильные решения билетов из сборника 4)Решения билетов для подготовки к экзамену 1С:
В публикации представлены только решения тех заданий, который попадаются на экзамене 1С:СК управленческого учета ERP. Благодаря данным решениям к экзамену стало подготовиться проще, чем когда-либо. В архиве находится решения 5 билетов, которые попадаются на реальном экзамене (другие билеты из
Экзамен 1С:Специалист по платформе 1С:Предприятие 8.3. Полные и правильные решения билетов из сборника 2022 В публикации предоставлено решения 7 билетов из сборника 2022 года . Решения выполнены по пунктам и подробно, каждый БП описан и решен по условиям задач. Благодаря данному решению к экзамену
Внешняя обработка предназначена для загрузки документов (прямое подключение к базе) в Бухгалтерия предприятия 3.0 из Управление торговлей за период по выбранной организации, и выгрузки документов по банку из Бухгалтерия предприятия 3.0 в Управление торговлей: В Бухгалтерию предприятия из Управление
Больше курсов по этой теме
ПРОГРАММА КУРСА: Теоретическая часть: Теоретические основы подсистемы «Бюджетирования». Настройка параметров программы для работы с подсистемой «Бюджетирования». Справочники подсистемы «Бюджетирования». Практическая часть: Анализ хозяйственных операций в подсистеме «Бюджетирования»: Анализ
В рамках курса детально разбираются различные операции, связанные с движением различных форм денежных средств в компании, включая работу с авансовыми отчетами, платежным календарем и установку лимитов расходования денежных средств. Также разбирается организация взаиморасчетов в системе, зачеты и
Видеозапись 134 минуты, рабочая тетрадь, методичка. УСН 2025: разбираем вопросы, с которыми уже столкнулся бизнес и с которыми еще столкнется Основные нововведения в сфере налогов с 2025 года Ключевые изменения 2025 по НДФЛ, налогу на прибыль, УСН Какие шаги предпринять, чтобы подготовиться к
Многим предпринимателям кажется, что патент является самым простым. ПСН не требует особых трудозатрат, отчетности и учета. Но у ПСН есть тоже подводные камни. Патент – одна из самых простых систем налогообложения для ИП и она удобнее многих других систем налогообложения. Но надо четко понимать, кто
Для кого: Лекция будет полезна для широкого круга слушателей: студентов экономических вузов и колледжей, практиков-экономистов, предпринимателей, а также представителей смежных специальностей Эксперт: Исмаилова Аида Замировна - кандидат экономических наук, преподаватель кафедры государственного и
Страховые взносы и НДФЛ 2024-2025: Важные нюансы по учету и оптимизации, о которых должен знать каждый бухгалтер Страховые взносы накладывают на бизнес существенную нагрузку, а неумение правильно определить базу для расчета, значительно увеличивает эту нагрузку. Практикум по страховым взносам
Отзывы о курсе [Инфостарт] Разбор XML документа - почти все возможные способы