Из таблицы значений в XML и обратно в процедурах по 4 строки кода

13.02.19

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

Иногда требуется перенести таблицу значений между базами через файл XML. Для этого предлагаю почти универсальный быстрый способ программной разработки без долгого описания типов, узлов, полей и т.д. На чтение или запись таблицы значений по 4 строки кода в процедурах.

Файлы

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

Наименование Скачано Купить файл
(только для физ. лиц)
ЗаписьТаблицыЗначенийВXML.epf – для обычной формы
.epf 8,58Kb
10 1 850 руб. Купить
ЗаписьТаблицыЗначенийВXMLУФ.epf – для управляемой формы
.epf 7,78Kb
20 1 850 руб. Купить
ЧтениеТаблицыЗначенийИзXML.epf – для обычной формы
.epf 6,78Kb
16 1 850 руб. Купить
ЧтениеТаблицыЗначенийИзXMLУФ.epf – для управляемой формы
.epf 7,34Kb
24 1 850 руб. Купить

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

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

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

Статья будет интересна для начинающих программистов 1С и тем, кто слышал про термины ФабрикаXDTO и СериализаторXDTO, но не использовал их для быстрого «общения» таблицы значений и файла XML.

Небольшое ограничение – типы данных в реквизитах обрабатываемой таблицы значений должны быть примитивные (Null, Неопределено, число, строка, дата) или одинаковые в базе из которой выгружается таблица значений и базе, в которую загружается таблица значений. При переносе ссылочных значений база может не найти такие типы значений, сообщит об этом. Это связано с тем, что ФабрикаXDTO содержит все пакеты XDTO, имеющиеся в конфигурации, а также предопределенные пакеты, т.е. «знает» объекты конфигурации и сама их описывает в файле XML. Если между конфигурациями переносится таблица только с примитивными типами – то нет проблем!

Даже синтакс-помощник версии 8.3.14.1565 для СериализаторXDTO.ЗаписатьXML не упоминает о работе с таблицей значений. Обработки тестировалось на версии 8.3.13.1513. Есть вероятность, что на «старых» версиях не будет работать – надо проверять.

Предлагаю рабочие обработки для обычных и управляемых форм, которые позволяют записать таблицу значений в файл XML всего в 4 строки, и обработки для чтения сохраненной таблицы значений из файла XML всего в 4 строки. Дополнительно в обработках используются различные приемы, например:

  • Формирование колонок по данным загруженной таблицы значений для обычных и управляемых форм.
  • В управляемой форме программное добавление таблицы значений с командной панелью и колонками по данным обрабатываемой таблицы значений.
  • Выбор любого доступного документа из базы и чтение выбранной табличной части в таблицу значений с возможность редактирования полученной таблицы значений и записи в файл XML.
  • В управляемой форме использование асинхронных методов для диалогов выбора файла.

Обработки для демонстрации записи таблицы значений в файл XML:

  • ЗаписьТаблицыЗначенийВXML.epf – для обычной формы
  • ЗаписьТаблицыЗначенийВXMLУФ.epf – для управляемой формы

Для примера формируется таблица значений из доступных данных любой табличной части любого документа. Необходимо выбрать тип документа, выбрать документ. Можно изменить выбранную табличную часть, по умолчанию выбирается первая табличная часть.

Кнопка «Заполнить таблицу» - очищает таблицу, создает необходимые колонки и заполняет таблицу значений данными выбранной табличной части. Данные таблицы можно редактировать.

Кнопка «Записать в XML» вызывает диалог выбора файла и сохраняет таблицу значений в файл XML.

Кнопка «Очистить таблицу» очищает данные таблицы.

Кнопка «Очистить все» очищает выбранные значения всех полей и данные таблицы.

Обработки для демонстрации чтения таблицы значений из файла XML:

  • ЧтениеТаблицыЗначенийИзXML.epf – для обычной формы
  • ЧтениеТаблицыЗначенийИзXMLУФ.epf – для управляемой формы

Кнопка «Прочитать таблицу их XML» - вызывает диалог выбора файла, очищает таблицу, создает необходимые колонки и заполняет таблицу значений данными из загруженного файла XML. Данные таблицы можно редактировать.

Если будет загружен файл с таблицей данных из другой базы с «незнакомыми» типами объектов – система сообщит о такой ошибке. В обычной форме для «незнакомых» полей будет указано, например:  <Объект не найден> (95:a31d14dae9b19a4811e61dcf2b5e5ea3), а другие данные будут загружены. В управляемой форме система полностью не загрузит данные, если есть «незнакомые» типы объектов.

Желательно подготовить данные перед выгрузкой, чтобы их можно было обработать в базе приемнике. Например – задать такое же имя поля для совпадающих типов или передавать уникальные идентификаторы вместо ссылок. Примитивные типы (Null, Неопределено, число, строка, дата) передаются без проблем между разными конфигурациями баз.

Кнопка «Очистить» очищает данные таблицы.

 

Файл XML, записанный этими обработками для демонстрации записи в обычной или управляемой форме, может быть прочитан любой этой обработкой для демонстрации чтения - в обычной или управляемой форме с учетом указанных ограничений. Если между конфигурациями переносится таблица только с примитивными типами – то нет проблем!

Надеюсь, что после демонстрации такого эффективного использования появится дополнительный интерес к изучению и использованию объектов ФабрикаXDTO и СериализаторXDTO.

XML ТаблицаЗначений ФабрикаXDTO СериализаторXDTO

См. также

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    148462    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    58780    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    27851    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    175135    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    191307    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    194246    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    163317    406    386    

532
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. MishaD 14 14.02.19 09:23 Сейчас в теме
А еще в 1с 7.7 были функции ЗначениеВФайл/ЗначениеИзФайла. Да и в 1с8 они тоже остались.
2. USER--1C 60 16.02.19 09:27 Сейчас в теме
Да, ЗначениеВФайл/ЗначениеИзФайла можно использовать для передачи данных через файл при работе в 1С. В этом случае используются формат не такой, как XML. Статья написана с целью облегчить написание программного кода именно при необходимости обмена в универсальном формате XML, используемом многими системами. На рисунке фрагмент начала двух файлов, сформированных разными способами.
Прикрепленные файлы:
Оставьте свое сообщение