Автоматическое создание XSD-файла по выбранным типам объектов конфигурации для загрузки в XDTO пакет в 1С 8.3

29.01.23

Интеграция - WEB-интеграция

Данная обработка позволяет создать XSD-файл по выбранным реквизитам Справочника, Документа, Плана видов характеристик и даже Плана обмена. В обработке есть возможность выбрать, какие стандартные и обычные реквизиты, а также реквизиты табличных частей попадут в XSD-файл. Также есть опциональная возможность автоматически добавить в XSD-файл все ссылочные типы, находящиеся в реквизитах (рекурсивным обходом).

Файлы

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

Наименование Скачано Купить файл
Автоматическое создание XSD-файла по выбранным типам объектов конфигурации для загрузки в XDTO пакет в 1С 8.3:
.epf 23,61Kb
147 1 850 руб. Купить

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

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

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

Данная обработка пригодится тем, кому нужно создать WEB-сервис который должен возвращать некоторые реквизиты для выбранного списка объектов метаданных. Например, нужны только:
- Наименование, Код, ИНН и КПП из Контрагентов;
- Наименование, Дата и Номер из Договоров;
- Документы Поступления НМА со списком принятых НМА;
- Документы Принятие к Учету НМА;

XML-схему всей конфигурации можно выгрузить в XSD-файл, а потом вычищать его, но это долго и неэффективно. К тому же в любой момент к документам НМА могут добавить ОС, а потом еще захотят Поступления номенклатуры и снова придется заниматься ручным трудом.

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


Порядок работы с обработкой:
1. Открываем обработку и добавляем в список необходимые типы:

2. Для каждого типа выбираем, какие реквизиты (включая стандартные и реквизиты табличных частей) нужно выгружать. Если нужны все реквизиты, то можно воспользоваться кнопками на командной панели, а если все реквизиты всех типов, то можно воспользоваться подменю «Для всех типов»

3. После этого достаточно выбрать папку выгрузки XSD-файла и нажать кнопку «Создать схему XSD» и в выбранной папке будет создан файл «XSD_schema.xsd». Если данный файл там уже есть – он будет перезаписан. А если Вы хотите, чтобы файл имел другое имя – задайте полный путь, включая ИмяФайла.xsd.
На скриншоте для выгрузки выбран реквизит СтранаРегистрации, который имеет тип Справочник.СтраныМира. Данный тип не выбран в Списке выгружаемых типов, поэтому по умолчанию такие реквизиты выгружаются с типом «anyType». Если Вы все же хотите, чтобы такие ссылочные типы были указаны верно, но не хотите выбирать множество мелких справочников типа Страны, Валюты, Банки и т.п. можно установить галочку «Создавать рекурсивную структуру подчиненных объектов». В этом случае справочник СтраныМира будет выгружен полностью (включая все реквизиты) и для каждого реквизита будет произведено рекурсивное добавление его ссылочных типов.

4. В ветке XDTO пакетов конфигуратора нажимаем  Правой кнопкой -  Импорт XML-схемы  и выбираем созданный XSD-файл.
В моей выгрузке я не устанавливал галочку «Создавать рекурсивную структуру подчиненных объектов», поэтому реквизит СтранаРегистрации имеет тип «anyType».

Данная обработка основана на публикации: infostart.ru/public/615256/
И содержит в себе множество доработок:
- Выгружаемые типы можно указывать списком. Данный список – не список ссылок, а список описаний типов.
- Расширены типы, которые можно указывать: Справочники, Документы, Плана видов характеристик и даже Плана обмена.
- В список реквизитов добавлены стандартные реквизиты (Ссылка, Дата, Код, Наименование и др.) и их выгрузку также можно отключить.
- Опциональная возможность включать рекурсивный обход типов, не указанных в списке выгружаемых, но присутствующих в реквизитах.
- Доработаны случаи, когда реквизит является ПланомСчетов, ПланомВидовХарактеристик, ПланыВидовРасчета или ПланомОбмена.
- Исправлены мелкие ошибки.
- Для решения собственной задачи Перечисления было решено выгружать с типом строка и не добавлять в его как отдельный тип в XSD-схему. Данная версия не работает с Перечислениями (тип EnumRef).


Протестировано на платформе 8.3.11.2899, но должно работать на любой 8.3.*

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

XSD XDTO WEB-сервисы

См. также

Сайты и интернет-магазины WEB-интеграция Системный администратор Программист Пользователь 1С v8.3 1C:Бухгалтерия 1С:Управление торговлей 11 Автомобили, автосервисы Россия Управленческий учет Платные (руб)

Интеграционный модуль обмена между конфигурацией Альфа Авто 5 и Альфа Авто 6 и порталом AUTOCRM / LOGICSTARS. Данный модуль универсален. Позволяет работать с несколькими обменами AUTOCRM / LOGICSTAR разных брендов в одной информационной базе в ручном и автоматическом режиме.

36000 руб.

03.08.2020    21816    31    24    

25

SALE! 15%

WEB-интеграция Программист Бизнес-аналитик 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Оптовая торговля, дистрибуция, логистика ИТ-компания Платные (руб)

Модуль "Экспортер" — это расширение для 1С, предназначенное для автоматизации процессов выгрузки данных. Оно позволяет эффективно извлекать, преобразовывать и передавать данные из систем 1С в интеграционную платформу Spot2D. Подсистема упрощает настройку, снижает количество ручных операций и обеспечивает удобный контроль данных.

17280 14688 руб.

20.12.2024    4034    20    2    

21

WEB-интеграция Программист Руководитель проекта 1С v8.3 1C:Бухгалтерия 1С:Франчайзи, автоматизация бизнеса Платные (руб)

Расширение значительно упрощает написание API на 1С. Веб программисты получают простой и понятный доступ к 1С. Описание API создаётся автоматически и представляется в виде удобном как для человека, так и для программной обработки. Основные преимущества: 1. Документация API создаётся автоматически. Удобна для программной обработки. 2. Изменить API столь же просто как настроить отчёт. Можно опубликовать существующий вариант отчёта. 3. Отчёты в API поддерживают параметры (Период, ДатаНачала и др.) 4. При создании простых методов не требуется изменять конфигурацию. 5. Поддерживается работа с планами обмена.<br/> 6. Возможно настроить отправку из 1С данных корреспондирующей системе, для случаев когда 1С сама "знает" какие данные нужно отправить. 7. После записи в 1С Ле Мурр может возвращать соответствие полученных идентификаторов созданным в 1С объектам данных.

36000 руб.

27.09.2024    8768    7    5    

10

Оптовая торговля WEB-интеграция Бюджетный учет Обмен с ГосИС Бухгалтер Пользователь 1С v8.3 1С:Комплексная автоматизация 1.х 1С:Бухгалтерия 2.0 1С:Управление торговлей 10 1С:Управление производственным предприятием 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Государственные, бюджетные структуры Россия Бухгалтерский учет Управленческий учет Платные (руб)

Обмен данными с "Порталом поставщиков" zakupki.mos.ru Москвы и Московской области с целью создания оферт для закупок государственными учреждениями. Модуль устраняет рутину, минимизирует ошибки и помогает выигрывать больше закупок. Работает строго по требованиям 44-ФЗ.

14400 руб.

13.12.2016    41351    54    39    

37

Обмен с ГосИС WEB-интеграция Бухгалтер Пользователь 1С v8.3 Управляемые формы 1С:Комплексная автоматизация 1.х 1С:Бухгалтерия 2.0 1С:Управление торговлей 10 1С:Управление производственным предприятием 1С:Управление нашей фирмой 1.6 1С:Бухгалтерия государственного учреждения 1С:Документооборот 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Платные (руб)

Обработка является альтернативой механизму, разработанному фирмой 1С и заполняющему реквизиты контрагента по ИНН или наименованию. Не требуется действующей подписки ИТС. Вызывается как внешняя дополнительная обработка, т.е. используется, непосредственно, из карточки контрагента. Заполнение по ИНН или наименованию реквизитов контрагента по данным сайта ФНС (egrul.nalog.ru) для БП 2.0, БП 3.0, БГУ 1.0, БГУ 2.0, УТ 10.3, УТ 11.x, КА 1.1, КА 2.x, УПП 1.x, ERP 2.x, УНФ 1.5, УНФ 1.6, УНФ 3.0, ДО 2.1

5196 руб.

28.04.2016    98301    111    218    

359
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. nbelyaev 838 23.10.18 06:54 Сейчас в теме
Идея хорошая, но какой практический смысл? Судя по скриншотам, такой пакет XDTO все равно придется дорабатывать руками. Может Вы скажите, где вы использовали, полученный таким образом ПакетXDTO? И еще интересно - что у Вас добавилось в дериктивы импорта?
2. w.r. 653 23.10.18 11:48 Сейчас в теме
Очень полезная штука для создания обменов! Спасибо!
yurazyuraz; al_zzz; +2 Ответить
3. mityushov.vv 265 23.10.18 14:54 Сейчас в теме
Добрый день, вот я делал что то подобное https://infostart.ru/public/615256/, но только у меня выгружаются все метаданные рекурсивно по выбранным реквизитам объекта, может будет полезной и для вас то же.
yurazyuraz; +1 Ответить
4. mityushov.vv 265 23.10.18 17:51 Сейчас в теме
(3) А это на основе моей обработки то и сделано)))) молодец
yurazyuraz; +1 Ответить
5. jobkostya1c_ERP 101 27.10.18 11:33 Сейчас в теме
Вот , дельная вещь. Надо запомнить и проверять.
6. mvxyz 331 08.12.18 10:22 Сейчас в теме
Полезный инструмент. Спасибо!
7. nkroshko 21.01.19 17:44 Сейчас в теме
Добрый день, а если в объекте есть реквизит составного типа, например с типами СправочникСсылка.Организации и СправочникСсылка.Контрагенты, то при установленном флаге "Создавать рекурсивную структуру подчиненных объектов" как будет формироваться схема? Будут ли в нее добавлены справочники Организации и Контрагенты? И какой тип при этом будет иметь реквизит со составным типом?
8. al_zzz 323 18.12.21 19:00 Сейчас в теме
Скачал, попробовал из БП3.0 выгрузить схему. Споткнулась на метаданном "Задание"(так-то я задания вообще не планировал выгружать). Но идея - огонь! Я поправлю и таки воспользуюсь данной обработкой.
Ещё хочу допилить в ней возможность сохранять и восстанавливать результаты промежуточной работы. Это, на мой взгляд, вообще очень важная возможность, так как в текущей задаче с вероятностью 99% придется менять схему и не хочется заново настройки набивать. Может быть, в обработке уже имеется она, да я просмотрел?
13. yurazyuraz 14.07.23 15:56 Сейчас в теме
(8) Да, спотыкается на задании - на бизнес процессе
Как поправить нашли вариант ?
14. al_zzz 323 14.07.23 19:43 Сейчас в теме
(13) Я не стал искать, а просто взял то, что есть и допилил уже вручную. Там ещё с перечислениями косяк - обработка их как строку конвертирует.
9. kit_extreme 76 23.05.22 10:10 Сейчас в теме
Для метаданных добавленных в расширений не работает - падает в ошибку
и с перечислениями проблема, не даёт выбрать
10. user1050439 8 02.07.23 16:25 Сейчас в теме
Создаю фабрику используя обработку https://infostart.ru/1c/tools/927540/, выбираю только часть реквизитов у объекта к выгрузке. затем создаю типы объекты на их основе, заполняю с ЗаполнитьЗначенияСвойств. Затем записываю в строку. Но в строке также видно, что при сериализации добавились и поля, которые не входят в типы упомянутые в схеме xsd (обработка позволяет обрезать некоторые типы объекта). Если это ссылочные типы, то они получают значение "00000000-0000-0000-0000-000000000000", а если это не ссылочные типы, они выгружаются как есть.

Как сделать чтобы лишнее не выгружалось?
11. yurazyuraz 13.07.23 17:29 Сейчас в теме
Очень полезная обработка!
12. yurazyuraz 14.07.23 10:49 Сейчас в теме
Судя по всему сделана на базе https://infostart.ru/public/615256
В описании не понятно в чем отличие от ориганала.
Оригинал я скачал штука полезная, но для себя сразу сделал вывод нужна небольшая доработка.
Этот инструмент позволяет быстро создать как минимум шаблон XDTO.

Сейчас как раз пишем обмен он-лайн между базами , прописывать XDTO весьма утомительное занятие.
15. yurazyuraz 17.07.23 16:25 Сейчас в теме
Вопрос к Автору

Для табличных частей не формируется

МаксимальноеКоличество = -1
МинимальноеКоличесто = 0
16. yurazyuraz 17.07.23 17:38 Сейчас в теме
Проблема в том что что для табличных частей обработка ставит

МаксимальноеКоличество = 1
МинимальноеКоличесто = 1

а надо что бы ставила

МаксимальноеКоличество = -1
МинимальноеКоличесто = 0
Прикрепленные файлы:
17. yurazyuraz 17.07.23 18:10 Сейчас в теме
Добавил код
Элемент = СоздатьЭлемент(ТабличнаяЧастьСтр, ДобСписокТипов, СоотвествиеСозданых, ОснПространствоИмен, ИмяТипа, Истина);

Схема.Содержимое[0].Содержимое.МаксимальноВходит =-1;
Схема.Содержимое[0].Содержимое.МинимальноВходит  = 0;


получилось поставить ,но на все реквизиты - на эти элементы ставить не надо Код , КоличествоПолосДлина
не могу найти как поставить только на этот элемент

<xs:element name="ЗатратыДляКалькуляции" type="tns:CatalogTabularSectionRow.ВариантыУпаковки.ЗатратыДляКалькуляции"/>


<?xml version="1.0" encoding="UTF-8"?>
<xs:schema xmlns:ent="http://v8.1c.ru/8.1/xdto" xmlns:tns="http://optisoftfull/Load" xmlns:v8="http://v8.1c.ru/8.1/data/core" xmlns:xs="http://www.w3.org/2001/XMLSchema" targetNamespace="http://optisoftfull/Load" attributeFormDefault="unqualified" elementFormDefault="qualified">
	<xs:import namespace="http://v8.1c.ru/8.1/xdto"/>
	<xs:complexType name="CatalogTabularSectionRow.ВариантыУпаковки.ЗатратыДляКалькуляции">
		<xs:sequence>
			<xs:element name="ВидЗатрат" type="xs:string"/>
		</xs:sequence>
	</xs:complexType>
	<xs:complexType name="CatalogObject.ВариантыУпаковки">
		<xs:sequence minOccurs="0" maxOccurs="unbounded">
			<xs:element name="Код" type="xs:string"/>
			<xs:element name="КоличествоПолосДлина" type="xs:decimal"/>
			<xs:element name="ЗатратыДляКалькуляции" type="tns:CatalogTabularSectionRow.ВариантыУпаковки.ЗатратыДляКалькуляции"/>
		</xs:sequence>
	</xs:complexType>
	<xs:complexType name="СписокОбъектов">
		<xs:sequence minOccurs="0" maxOccurs="unbounded">
			<xs:element name="ВариантыУпаковки" type="tns:CatalogObject.ВариантыУпаковки"/>
		</xs:sequence>
	</xs:complexType>
</xs:schema>

Показать
Для отправки сообщения требуется регистрация/авторизация