Разборка-сборка XML

10.02.12

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

Используя эту разработку, можно обрабатывать XML как  дерево значений 1С, даже не умея читать или записывать XML.

Файлы

ВНИМАНИЕ: Файлы из Базы знаний - это исходный код разработки. Это примеры решения задач, шаблоны, заготовки, "строительные материалы" для учетной системы. Файлы ориентированы на специалистов 1С, которые могут разобраться в коде и оптимизировать программу для запуска в базе данных. Гарантии работоспособности нет. Возврата нет. Технической поддержки нет.

Наименование Скачано Купить файл
(только для физ. лиц)
down.zip
.zip 89,08Kb
228 1 850 руб. Купить

Подписка PRO — скачивайте любые файлы со скидкой до 85% из Базы знаний

Оформите подписку на компанию для решения рабочих задач

Оформить подписку и скачать решение со скидкой

Если вам лень заниматься чтением и записью XML, то используя эту разработку, вы можете обрабатывать XML как обычное дерево значений.

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

Но если файлы средних размеров, метод имеет право на жизнь.

Для разбора XML вы должны использовать код вида:

Ч = Новый ЧтениеXML();

Ч.ОткрытьФайл(ИмяГлавногоФайла);

П = ___обРазобратьXML(Ч);

Ч.Закрыть();

 

Все, XML файл прочитается, и запишется в структуру с полями:

Дерево - дерево разбора

Кодировка - кодировка XML

Дерево - это дерево с колонками:

Тег - имя тега

Тело - тело тега

Атрибуты – соответствие: в ключах - имена атрибутов, в значениях - значения атрибутов.

Тип - пустая колонка, зарезервирована

Вы можете обработать дерево и записать полученный результат в файл.

А можно просто создать структуру с такой же структурой и программно заполнить дерево нужной структурой XML:

П = Новый Структура();

П.Вставить("Кодировка", Ч.КодировкаИсточника);

Дерево = Новый ДеревоЗначений();

Дерево.Колонки.Добавить("Тег");

Дерево.Колонки.Добавить("Тело");

Дерево.Колонки.Добавить("Атрибуты");

Дерево.Колонки.Добавить("Тип");

П.Вставить("Дерево", Дерево);

 

Чтобы записать дерево в XML строку, используется код вида:

З = Новый ЗаписьXML;

З.УстановитьСтроку(П.Кодировка);

___обСобратьXML(П, З);

РезСтрока = З.Закрыть();

 

Чтобы записать дерево в XML файл, используется код вида:

З = Новый ЗаписьXML;

З.ОткрытьФайл(ИмяФайла);

___обСобратьXML(П, З);

З.Закрыть();

 

В обработке для примера файл разбирается, а затем собирается. Можно посмотреть на различия после разборки-сборки.

См. также

SALE! 10%

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

27660 24894 руб.

12.06.2017    148439    864    302    

455

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

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

35000 руб.

23.07.2020    58761    284    75    

224

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

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

35000 руб.

15.12.2021    27842    198    58    

153

SALE! 10%

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

Перенос данных из 1С:Управление производственным предприятием 1.3 в 1С:Бухгалтерия предприятия 3.0 с помощью правил обмена | Можно выполнить переход с УПП на БП 3 или запускать выгрузку данных за выбранный период времени | Переносятся документы, начальные остатки и вся справочная информация | Есть фильтр по организации и множество других параметров выгрузки | Поддерживается несколько сценариев работы: как первичный полный перенос, так и перенос только новых документов | Перенос данных возможен в "1С: Бухгалтерия 3.0" версии ПРОФ, КОРП или базовую | Переход с "1С: УПП1.3" / "1С:КА 1.1" на "1С:БП3.0" с помощью правил конвертации будет максимально комфортным! | Можно бесплатно проверить перенос на вашем сервере!

48278 43450 руб.

25.02.2015    175108    319    267    

388

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

Регулярный обмен, выгрузка, перенос из КА 1.1, УПП 1.3, УТ 10.3 для обмена с любыми конфигурациями, поддерживающими обмен в формате EnterpriseData (КД3) - БП 3.0, ERP, КА 2, УТ 11, Розница 2, УНФ 1.6 и другими. Правила для старых и доработанных конфигураций не требуют синхронного обновления и совместимы с новыми и будущими конфигурациями. Обмен по расписанию, через папку, FTP, почту.

16260 руб.

18.02.2016    191230    626    536    

545

SALE! 10%

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

Перенос данных из КА 1.1 в КА 2 | из КА 1.1 в УТ 11 | Воспользовались более 367 компаний! | Переносятся все возможные виды документов, начальных остатков и вся справочная информация из "1С:КА 1.1" в "1С:КА 2.х" / "1С:УТ 11" | Разработан в формате КД 2 (правила конвертации данных) | Фильтр по организациям при выгрузке | Выбор разных алгоритмов выгрузки начальных остатков | Можно проверить перенос до покупки!

55778 50200 руб.

04.12.2015    194216    254    351    

409

Загрузка и выгрузка в 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 1С:Розница 3.0 Платные (руб)

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

18000 руб.

20.11.2015    163238    406    386    

532
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. stormtg 13.02.12 14:38 Сейчас в теме
Хм, интересный взгляд, спасибо посмотрим
2. fixin 4290 13.02.12 15:34 Сейчас в теме
(1) ну что вы, это хит... взлетит еще...
3. Aragorn 14.02.12 12:50 Сейчас в теме
надо будет попробовать, только жалко инфорублей нет
4. necropunk 11 15.02.12 11:56 Сейчас в теме
Хм... Потестируем. Писал похожую вещь когда-то, интересно будет сравнить.
5. fzt 15.02.12 12:41 Сейчас в теме
Хм, а подключить через ActiveX готовый скрипт на VBS было бы проще.
Работу посмотрел - понравилось. Но её действительно было возможно избежать.
6. fixin 4290 15.02.12 16:30 Сейчас в теме
(5) смысл? суть этой разработки - работать с XML через привычный объект дерево. Т.е. тупой 1сник может ничего не знать об XML и тем не менее, с ним работать. Особенно актуально для тех, кто до сих пор использует DBF.
7. fzt 20.02.12 10:02 Сейчас в теме
Солидарен, в такой форме постановки вопроса я тоже думаю что актуально =)
За offtopом можно оставить актуальность самого мм.. специалиста - как пользователя.
8. Новиков 292 20.02.12 10:07 Сейчас в теме
мне не понятно, зачем использовать это, вместо того, что используется в типовых как де-факто?
9. fixin 4290 20.02.12 10:37 Сейчас в теме
(8) а что именно используется в типовых де-факто?
Моя разработка - для упрощения разбора XML для тех, кто там ни в зуб ногой. Но кто хорошо знает саму 1С и работу с деревом значений.
Да и сам я юзал эту функцию, когда юзал HTTP запросы. Там ответы приходили в виде небольшого XML и мне было проще кинуть ответ в дерево значений, чем писать парсингъ XML.


(7) че то я не понял о чем вы.
10. Новиков 292 20.02.12 11:47 Сейчас в теме
(9) а что мешает открыть и взглянуть? :) Мне кажется, у вас - велосипед. Я не говорю, что это плохо. Просто хотелось понять - а зачем он, если можно утащить сие из типовой, с аналогичной функциональностью? :)
11. fixin 4290 20.02.12 15:28 Сейчас в теме
(10) я работаю с типовыми. Но до сих пор не могу понять, о чем вы собственно, ведете речь. Может это и велосипед, но это именно инструмент для тех, кому неохота париться с ХМЛ. Бац-бац и вместо ХМЛ уже дерево значений.
А вы о чем речь ведете? Что-то я никак не пойму ваших намеков.
12. iotkin 29.02.12 11:44 Сейчас в теме
Большое спасибо за обработку. С удовольствием плюсую!!!
13. KliMich 13.03.12 15:36 Сейчас в теме
Спасибо! Интересный подход
14. premierex 207 13.03.12 16:01 Сейчас в теме
Минус - только за стиль программирования. Чтобы использовать этот код в своих целях, его придётся полностью переписывать! Важно не только то, ЧТО ты написал, но ещё и КАК ты это написал. Народ, как такой код читается, легко?
Кстати, на ИТС есть рекомендации по оформлению кода от 1С. Советую ознакомиться!
Seneka7608; fixin; +2 Ответить
15. fixin 4290 13.03.12 16:36 Сейчас в теме
(14) код писал давно, возможно форматирование еще старое. Я потом перешел на нормальное.
Но чтобы юзать, достаточно только вызывать нужную функцию. Не вижу проблем.
16. AlexO 136 17.03.12 13:59 Сейчас в теме
Загружал файл более 10Мб - зависла обработка.
Пробовал несколько раз.
и нет поиска.
18. fixin 4290 17.03.12 16:49 Сейчас в теме
(16) а что вы хотели. Это тулза для чтения небольших XML. Она ведь разбирает XML в дерево. А размер коллекций в 1С ограничен. Для чтения больших ХМЛ юзайте ЧтениеХМЛ.
19. AlexO 136 17.03.12 16:52 Сейчас в теме
(18)
тогда печально все....
ЧТо за обработка "ЧтениеХМЛ"? что вы под ней подразумеваете?
21. fixin 4290 17.03.12 23:07 Сейчас в теме
(19)(20)
ничего печального нет. Часто надо парсить маленькие XML.
А большие XML в любом случае надо читать через последовательное чтение. В 1с для этого есть объект ЧтениеXML.
Вообще существуют два способа разбора XML - или вы его целиком загружаете в память (как в моем методе) или последовательно читаете из файла.
Чудес не бывает.
17. AlexO 136 17.03.12 16:49 Сейчас в теме
Сергей, если интересно - могу сбросить xml
20. AlexO 136 17.03.12 16:54 Сейчас в теме
И данная обработка - только для файлов до 5МБ?
22. Magister 134 17.03.12 23:30 Сейчас в теме
Делал относительно недавно что-то наподобии, но ещё и с автоматическим преобразованием типов - как простых, так и ссылочных.
Соответствие типов задается через макет, так же контроль заполненности реквизитов.
Стоит публиковать?
23. fixin 4290 18.03.12 00:31 Сейчас в теме
(22) если ты не заново изобрел XDTO, то публикуй
24. AlexO 136 22.03.12 11:17 Сейчас в теме
Кстати, а ведь есть XML_парсеры, которые прекрасно и быстро грузят много мегабайтные xml-ки в дерево...
25. fixin 4290 22.03.12 11:53 Сейчас в теме
(24) проблема не в том, что у меня плохой парсер (у меня как раз последовательный парсер Чтение XML, который память не напрягает). Проблема в том, что коллекции в 1С (дерево, например) большого размера не выживают.
26. AlexO 136 22.03.12 12:03 Сейчас в теме
(25)
т.е. с коллекцией Дерево в 1с какие-то проблемы?
ведь в тех, других, парсерах тоже в дереве все выводится...
насчет памяти не скажу, но очень быстро.
27. fixin 4290 22.03.12 12:27 Сейчас в теме
(26) у меня тоже в дерево все очень быстро выводится. Но огромное дерево просто тупо вешает 1с. Проблема была именно в этом. ;-) Кстати, большие XML файлы поэтому и не читаются через парсеры а-ля DOM, что памяти не хватает. Только последовательно!
28. AlexO 136 22.03.12 14:50 Сейчас в теме
(27)
ну хотите, поделюсь парсером - и не вешает, и открывает большие файлы ))
внутри еще не копался - не скажу, DOM там, или не DOM...
29. fixin 4290 22.03.12 16:28 Сейчас в теме
(28) делитесь, но смотреть некогда. ;-)
30. AlexO 136 22.03.12 17:32 Сейчас в теме
(29)
с сайта MyKoD.info:
Прикрепленные файлы:
XML редактор v1.epf
32. fixin 4290 22.03.12 17:56 Сейчас в теме
(30)(31) и какие файлы ты туда пробовал заливать по размеру? 10-мбайтовый файл пробовал загружать?
31. AlexO 136 22.03.12 17:35 Сейчас в теме
(29)
или вот, разработала некая девушка Маша, доработал o-Planet:
парсер XML
Оставьте свое сообщение