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

10.02.12

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

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

Скачать файлы

Наименование Файл Версия Размер
down.zip
.zip 89,08Kb
228
.zip 89,08Kb 228 Скачать

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

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

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

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

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

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

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

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

 

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

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

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

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

Тег - имя тега

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

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

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

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

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

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

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

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

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

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

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

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

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

 

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

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

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

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

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

 

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

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

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

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

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

 

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

См. также

SALE! 10%

[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 руб.

12.06.2017    134617    719    291    

387

Перенос данных из УПП 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 руб.

15.12.2021    20100    133    38    

90

SALE! 10%

Перенос данных из ERP 2 / КА 2 в ЗУП 3

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

Обработка позволяет не только перенести все документы, справочную информацию и начальные остатки из ERP 2 или КА 2 в ЗУП 3, но и организовать регулярный перенос данных между программами 1С:ERP 2 / КА 2 и 1С:ЗУП 3. Вы можете выбрать период отбора данных и установить фильтр по организациям, чтобы выгружать только необходимую информацию. Более того, перенос оперативно обновляется при выходе новых релизов программы 1С, так что вы всегда будете иметь самую актуальную версию обработки.

48278 43450 руб.

03.12.2020    34044    80    57    

78

SALE! 10%

Перенос данных из ERP 2 / КА 2 / УТ 11 в БП 3.0

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

Перенос позволяет настроить собственный обмен данными между указанными программами, альтернативный предлагаемому фирмой 1С. Перенос данных осуществляется из 1С:ERP 2 / 1С:КА 2 / 1С:УТ 11 в 1С:БП 3.0. Правила обмена оперативно обновляются при выходе новых релизов программы 1С, так что вы всегда будете иметь самую актуальную версию обработки.

38500 34650 руб.

15.04.2019    68206    176    136    

108

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

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

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

60000 руб.

05.10.2022    9157    9    8    

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 руб.

23.07.2020    46026    194    64    

153

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 Россия Платные (руб)

Обработка позволяет начать вести учет в программе "1С:Управление нашей фирмой" редакции 3.0 или 1.6, то есть перенести в нее из существующей базы "1С:Бухгалтерия предприятия, ред. 3.0" начальные остатки на выбранную дату, документы за период времени и также всю необходимую справочную информацию. По вашему запросу мы можем бесплатно добавить в правила переноса дополнительные виды объектов (например, новые виды документов). Обработка по переходу на новую программу 1С включает в себя правила конвертации в формате XML, обработку для выгрузки и загрузки данных, а также инструкцию по работе.

50722 45650 руб.

10.07.2018    67290    41    118    

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    150387    365    375    

499
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. stormtg 13.02.12 14:38 Сейчас в теме
Хм, интересный взгляд, спасибо посмотрим
2. fixin 4252 13.02.12 15:34 Сейчас в теме
(1) ну что вы, это хит... взлетит еще...
3. Aragorn 14.02.12 12:50 Сейчас в теме
надо будет попробовать, только жалко инфорублей нет
4. necropunk 9 15.02.12 11:56 Сейчас в теме
Хм... Потестируем. Писал похожую вещь когда-то, интересно будет сравнить.
5. fzt 15.02.12 12:41 Сейчас в теме
Хм, а подключить через ActiveX готовый скрипт на VBS было бы проще.
Работу посмотрел - понравилось. Но её действительно было возможно избежать.
6. fixin 4252 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 4252 20.02.12 10:37 Сейчас в теме
(8) а что именно используется в типовых де-факто?
Моя разработка - для упрощения разбора XML для тех, кто там ни в зуб ногой. Но кто хорошо знает саму 1С и работу с деревом значений.
Да и сам я юзал эту функцию, когда юзал HTTP запросы. Там ответы приходили в виде небольшого XML и мне было проще кинуть ответ в дерево значений, чем писать парсингъ XML.


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