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

13.02.19

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

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

Файлы

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

Наименование Скачано Купить файл
ЗаписьТаблицыЗначенийВXML.epf – для обычной формы
.epf 8,58Kb
10 2 500 руб. Купить
ЗаписьТаблицыЗначенийВXMLУФ.epf – для управляемой формы
.epf 7,78Kb
22 2 500 руб. Купить
ЧтениеТаблицыЗначенийИзXML.epf – для обычной формы
.epf 6,78Kb
17 2 500 руб. Купить
ЧтениеТаблицыЗначенийИзXMLУФ.epf – для управляемой формы
.epf 7,34Kb
26 2 500 руб. Купить

Подписка 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

См. также

НДС 22% Учетные задачи ККМ Файловый обмен (TXT, XML, DBF), FTP 1С 8.3 1С:Комплексная автоматизация 1.х 1С:Управление торговлей 10 1С:Управление производственным предприятием Бухгалтерский учет Налоговый учет НДС Платные (руб)

Готовое обновление для конфигурации 1С:Управление торговлей 10.3, 1С:Комплексная автоматизация 1.1 , 1С:Управление производственным предприятием 1.3 обеспечивающее полную поддержку новой ставки НДС 22%. Для 1С:УТ 10.3 реализована поддержка печати чеков ККМ, а также Правила обмена с 1С:БП 3.0. Решение встраивает необходимые изменения в перечисления и документы, включая торговые операции и печатные формы.

12200 руб.

16.12.2025    6850    79    0    

73

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист 1С:Предприятие 8 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" с помощью правил конвертации будет максимально комфортным! | Можно бесплатно проверить перенос на вашем сервере!

50050 руб.

25.02.2015    180641    348    283    

409

Перенос данных 1C Файловый обмен (TXT, XML, DBF), FTP Системный администратор Программист 1С:Предприятие 8 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. Не требуется синхронного обновления правил после обновления другой конфигурации, участвующей в обмене. Типовой обмен через планы обмена кнопкой Синхронизация вручную или автоматически по расписанию, или вручную обработкой.

22650 руб.

12.06.2017    157373    939    306    

475

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

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

38000 руб.

15.12.2021    32242    237    61    

177

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

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

58000 руб.

29.10.2018    60979    76    128    

74

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

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

38000 руб.

23.07.2020    65495    304    83    

243

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

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

16531 руб.

18.02.2016    198590    661    543    

560
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
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, используемом многими системами. На рисунке фрагмент начала двух файлов, сформированных разными способами.
Прикрепленные файлы:
Для отправки сообщения требуется регистрация/авторизация