Разборка-сборка 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(П, З);

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

 

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

Вступайте в нашу телеграмм-группу Инфостарт

См. также

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

12.06.2017    152524    890    302    

462

SALE! 10%

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

55778 50200 руб.

15.04.2019    78844    212    163    

150

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    178010    327    275    

396

SALE! 10%

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

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

53111 47800 руб.

03.12.2020    41879    119    75    

112

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

Федеральная таможенная служба России давно поддерживает унифицированный формат электронных документов для обмена с информационными системами предприятий. xmlns="urn:customs.ru:Information:ExchangeDocuments:". Структура, утвержденная комиссией Таможенного союза. Осталось только сделать загрузку в 1С из этого формата. На выходе - два документа ГТД по импорту и Поступление (акты, накладные) Обработка актуализирована на начало 2025 года

4800 руб.

09.08.2016    88694    331    378    

90

Перенос данных 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.24.x).

38000 руб.

23.07.2020    61447    289    81    

229

Загрузка и выгрузка в 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 форматов без офиса, на любом сервере! Визуальное связывание колонок файла и реквизитов простым перетаскиванием колонок. Создание или обновление номенклатуры с иерархией, характеристик, доп. реквизитов, упаковок, загрузка практически неограниченного количества картинок на одну номенклатуру (с возможностью загрузки в несколько потоков одновременно), с хранением в томах или в базе. Загрузка номенклатуры поставщиков или поиск по их данным номенклатуры. Загрузка доп. реквизитов в характеристики. Загрузка штрихкодов с генерацией новых. Создание элементов справочников и ПВХ "на лету" для выбранных реквизитов. (Обновление от 24.09.2025, версия 9.12 - 10.4)

19200 руб.

20.11.2015    167340    417    386    

538

SALE! 10%

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

Правила переноса кадровых и расчетных данных и справочной информации из "1С:УПП1.3" или "1С:КА 1.1" в "1С:ЗУП 3.1 | Разработан в формате КД 2 (правила конвертации данных) | При выгрузке есть фильтр по организациям | Обновляется при выходе новых релизов 1С | Развитие алгоритмов | Расчетные документы переносятся в документ "Перенос данных" | Создаются документы "Начальная штатная расстановка" и "Начальная задолженность по зарплате", переносятся кадровые документы

55778 50200 руб.

29.10.2018    59040    67    121    

67
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. stormtg 13.02.12 14:38 Сейчас в теме
Хм, интересный взгляд, спасибо посмотрим
2. fixin 4299 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 4299 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 4299 20.02.12 10:37 Сейчас в теме
(8) а что именно используется в типовых де-факто?
Моя разработка - для упрощения разбора XML для тех, кто там ни в зуб ногой. Но кто хорошо знает саму 1С и работу с деревом значений.
Да и сам я юзал эту функцию, когда юзал HTTP запросы. Там ответы приходили в виде небольшого XML и мне было проще кинуть ответ в дерево значений, чем писать парсингъ XML.


(7) че то я не понял о чем вы.
10. Новиков 292 20.02.12 11:47 Сейчас в теме
(9) а что мешает открыть и взглянуть? :) Мне кажется, у вас - велосипед. Я не говорю, что это плохо. Просто хотелось понять - а зачем он, если можно утащить сие из типовой, с аналогичной функциональностью? :)
11. fixin 4299 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 4299 13.03.12 16:36 Сейчас в теме
(14) код писал давно, возможно форматирование еще старое. Я потом перешел на нормальное.
Но чтобы юзать, достаточно только вызывать нужную функцию. Не вижу проблем.
16. AlexO 136 17.03.12 13:59 Сейчас в теме
Загружал файл более 10Мб - зависла обработка.
Пробовал несколько раз.
и нет поиска.
18. fixin 4299 17.03.12 16:49 Сейчас в теме
(16) а что вы хотели. Это тулза для чтения небольших XML. Она ведь разбирает XML в дерево. А размер коллекций в 1С ограничен. Для чтения больших ХМЛ юзайте ЧтениеХМЛ.
19. AlexO 136 17.03.12 16:52 Сейчас в теме
(18)
тогда печально все....
ЧТо за обработка "ЧтениеХМЛ"? что вы под ней подразумеваете?
21. fixin 4299 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 4299 18.03.12 00:31 Сейчас в теме
(22) если ты не заново изобрел XDTO, то публикуй
24. AlexO 136 22.03.12 11:17 Сейчас в теме
Кстати, а ведь есть XML_парсеры, которые прекрасно и быстро грузят много мегабайтные xml-ки в дерево...
25. fixin 4299 22.03.12 11:53 Сейчас в теме
(24) проблема не в том, что у меня плохой парсер (у меня как раз последовательный парсер Чтение XML, который память не напрягает). Проблема в том, что коллекции в 1С (дерево, например) большого размера не выживают.
26. AlexO 136 22.03.12 12:03 Сейчас в теме
(25)
т.е. с коллекцией Дерево в 1с какие-то проблемы?
ведь в тех, других, парсерах тоже в дереве все выводится...
насчет памяти не скажу, но очень быстро.
27. fixin 4299 22.03.12 12:27 Сейчас в теме
(26) у меня тоже в дерево все очень быстро выводится. Но огромное дерево просто тупо вешает 1с. Проблема была именно в этом. ;-) Кстати, большие XML файлы поэтому и не читаются через парсеры а-ля DOM, что памяти не хватает. Только последовательно!
28. AlexO 136 22.03.12 14:50 Сейчас в теме
(27)
ну хотите, поделюсь парсером - и не вешает, и открывает большие файлы ))
внутри еще не копался - не скажу, DOM там, или не DOM...
29. fixin 4299 22.03.12 16:28 Сейчас в теме
(28) делитесь, но смотреть некогда. ;-)
30. AlexO 136 22.03.12 17:32 Сейчас в теме
(29)
с сайта MyKoD.info:
Прикрепленные файлы:
XML редактор v1.epf
32. fixin 4299 22.03.12 17:56 Сейчас в теме
(30)(31) и какие файлы ты туда пробовал заливать по размеру? 10-мбайтовый файл пробовал загружать?
31. AlexO 136 22.03.12 17:35 Сейчас в теме
(29)
или вот, разработала некая девушка Маша, доработал o-Planet:
парсер XML
Для отправки сообщения требуется регистрация/авторизация