1с прочитать xml в таблицу значений
В основе работы с XML-файлами лежит технология доступа SAX, которая осуществляет считывание по одному тегу. Для этого существует два типа данных – ЗаписьXML и ЧтениеXML.
Запись данных справочника в XML-файл:
Код 1C v 8.х
Чтение данных из XML-файла в справочник:
Код 1C v 8.х
Создадим обработку в типовой конфигурации для экспорта плана счетов. Структура xml-файла должна быть такой. Корневой элемент xml-документа соответствует плану счетов в целом. В нем располагаются подчиненные элементы с именем Счет, содержащие информацию о счетах. В качестве содержимого элементов указывается наименование счета. Остальные данные записываются в качестве атрибутов (код, признаки валютного, количественного учета и пр.). В качестве подчиненных элементов для элемента Счет задаются элементы, обозначающие его субсчета с теми же атрибутами. Приведем код процедуры экспорта плана счетов.
Код 1C v 7.x
В результате будет получен файл, вот его фрагмент:
Код
<?xml version="1.0" encoding="windows-12Sl" ?> - <ПланСчетов>
<Счет Код="00" Валютный="0" Количественный="0" Забалансовый="0" вид="активно-пассивный">Вспомогательный</Счет>
- <Счет Код="01" Валютный="0" Количественный="0" Забалансовый="0" вид="активный">
Основные средства
<Субсчет Код="01.1" Валютный="0" Количественный="0" Забалансовый="0"
вид="активный">ОС в организации</Субсчет> <Субсчет Код="01.2" Валютный="0" Количественный="0" Забалансовый="0"
вид="активный">Выбытие ОС</Субсчет> </Счет>
- <Счет Код="02" Валютный="0" Количественный="0" Забалансовый="0" вид="пассивный">
Амортизация ОС
А теперь приведем код для импорта плана счетов из xml-файла в новую конфигурацию. Код модуля соответствующей обработки должен содержать процедуру Выполнить(), которая имеет такой вид.
Статья будет интересна для начинающих программистов 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 в дерево, в таблицу значений, в массив или как в этой заметке — в структуру. У всех этих способов есть свои плюсы и минусы.
Плюсы подхода изложенного в этой заметке — типизация полученного результата.
Минусы — время работы, объем потребляемой памяти. Поэтому для чтения больших файлов (более 5 kb) слабо подходит.
Для примера используется такое определение XSD
и вот такой xml для теста
При помощи этого кода легко и быстро можно превратить входящий xml в структуру и затем уже работать с ней в своем приложении.
Вот так будет выглядеть корневой элемент
В обработке прикрепленной к заметке — тот же самый код (плюс несколько несложных сервисных функций)
Related Posts
6 Comments
Пхе. В своё время я написал функцию-универсалку, которая любой XDTO-объект раздербанивает в коллекции 1С (например, в дерево, в строках которого массивы, или структуры, или ещё что, короче, полностью соответствуя структуре исходного объекта). Короче, усложнённый вариант вашей версии. Разумеется, исходя из его URI и фабрики. Но и то публиковать не стал, ибо техническая вспомогательная хрень.
Если СвойствоXDTO.НижняяГраница=0 и СвойствоXDTO.ВерхняяГраница=-1 Тогда // списочный
ну или учитывать, что кол-во в списке может быть ограничено, и тогда уж исходя из него ))
Данная статья не претендует на оригинальность и не является конечным решением.
Подходы решения задач и примеры программного кода несут исключительно обучающий характер.
Существует масса подходов загрузки данных из EXCEL в 1С. Большинство решений основаны на COM или еще более сложных возможностях платформы.
Для себя разработал наиболее оптимальный вариант:
EXCEL -> Табличный документ -> Построитель запроса -> Таблица значений
-
Прочитать Excel файл на клиенте, для передачи на сервер:
Визуализировать таблицу значений:
Описание преобразования данных:
Related Posts
41 Comments
Не нужно плодить временные сущностифайлы!
Заменить на одну строку:
Автор гений Спасибо.
(2)через поток читает только ods и mxl, к сожалению.
Это работает только для xlsx
К сожалению, xls не прочитает.
(0) О Боже автор наконец-то освоил уже устаревший метод Прочитать!
(7) С какого это перепуга не сработает. Все прекрасно там работает!
Тем более, что статья писана для начинающих, и это обязательно будет вводить их в ступор и/или приучать к бардаку в коде.
(12) Добрый день! Сухая критика автора ни к чему не приведёт. Вот что действительно поможет комьюнити, напишете как сделали бы Вы, или поделитесь полезными ссылочками дабы предотвратить бардак в коде.
(8) Больше поражает сколько плюсов статья получила))
(11) Если количество листов в документе больше 20, то так же виснет намертво
(13) она универсальная, а не заточенная под конкретную задачу, если и удастся самому приложив усилия импортировать конкретный документ и все сопутствующие справочники и регистры сведений, то никак не получится заставить ей пользоваться рядовых пользователей в ежедневной рутинной работе.
(9) А что плохого в построителе?
(9) Отнюдь, удобней способа выгрузить табличный документ в ТЗ и наоборот ещё поискать
Почему нельзя вынести работу с файлом на клиент? А уже полученный Табличный документ передать на сервер? Тогда временный файл вроде как не нужен
при этом эксель не был установлен на компе.
а так как я не использую чтение эксель, а использую для обработки информации mxl, то мне этого достаточно (можете мои загрузки из эксель поизучать)
ОбластьТаблицы = ТабличныйДокумент.Область(8, 1, ТабличныйДокумент.ВысотаТаблицы, ТабличныйДокумент.ШиринаТаблицы);
ПостроительЗапроса.ИсточникДанных = Новый ОписаниеИсточникаДанных(ОбластьТаблицы);
А что, так можно было?)
Не знал, спасибо, автор)
Автор хотел донести общую суть самого простого способа загрузки из Excel.
Данное решение не пригодно для больших таблиц потому что платформа 1С8 пока не умеет работать с табличными документами так же быстро как это делает Эксель. Данное решение пригодно исключительно для мелких файлов.
(24) Соглашусь. Построитель иногда очень эффективен. И я в своё время его много изучал, и сейчас использую. Любой инструмент должен быть адекватен своему контексту применения.
Отличная реализация частой задачи!
Можно читать и через ТабДок, но есть ньюансы .
(38) а про нюансы люди сами узнают, когда попытаются это применить))) плюсов, смотрю, вообще уже запредельное количество. Как и желающих с размаху встать на грабли)
Плюсанул только за функцию ТаблицаЗначенийВТабличныйДокумент, как то запамятовал что построитель отчета может по таблице значений выводить табличный документ. Иногда нужно вывести какую нибудь простенькую таблицу ошибок обработки например или какую нибудь отладочную инфу пользователю, а городить макет и вывод в табдок не хочется.. вот тут то эта функция будет самое оно. Кстати функция прокатит и для РезультатаЗапроса, а не только для ТаблицыЗначений.
А по поводу загрузки из экселя функция увы совсем не универсальная будет из за построителя запроса, он совсем не все подряд кушает, но если есть простенькая четко структурированная табличка, то вполне прокатит.
Читайте также: