Проверка по схеме XML-файла (валидация по XSD)

03.10.13

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

Обработка позволяет проводить проверку по схеме (валидацию) XML-файлов в среде Windows

Скачать файлы

Наименование Файл Версия Размер
ВалидацияXML.epf
.epf 13,57Kb
216
.epf 1.00 13,57Kb 216 Скачать

Довольно часто возникает необходимость проверки соответствия XML-файлов представленной схеме (XSD), но под рукой не оказывается программы, обладающей этим функционалом. Представляемая Вашему вниманию обработка очень компактна, не требует установки, и позволяет справиться с этой задачей в среде 1С:Предприятие 8.2 и выше под Windows.

Системные требования: необходимо наличие служб MSXML 6.0. Во всех современных версиях Windows (начиная с Vista и позже) они присутствуют после установки. Если же версии Windows старые (XP/2003), тогда может понадобиться их установка (взять можно здесь), но, скорее всего, даже на этих версиях Windows они уже установлены, если система периодически обновляется. Так что рекомендую сначала попробовать обработку, и только в случае неудачи устанавливать службы MSXML 6.0.

XSD XML валидация проверка схема

См. также

SALE! 10%

Перенос данных из ERP 2 / КА 2 / УТ 11 в БП 3.0

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

Перенос позволяет настроить собственный обмен данными между указанными программами, альтернативный предлагаемому фирмой 1С. Перенос данных осуществляется из 1С:ERP 2 / 1С:КА 2 / 1С:УТ 11 в 1С:БП 3.0. Правила обмена оперативно обновляются при выходе новых релизов программы 1С, так что вы всегда будете иметь самую актуальную версию обработки.

38500 34650 руб.

15.04.2019    67772    175    136    

107

SALE! 15%

[ED3] Обмен для ERP 2.5, КА 2.5, УТ 11.5 БП 3.0, Розница, УНФ и других с EnterpriseData (универсальный формат обмена), правила обмена

Обмен между базами 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. Не требуется синхронного обновления правил после обновления другой конфигурации, участвующей в обмене. Типовой обмен через планы обмена кнопкой Синхронизация вручную или автоматически по расписанию, или вручную обработкой.

25080 руб.

12.06.2017    133577    713    291    

383

Перенос данных из УПП 1.3 в БП 3.0. Переносятся документы (обороты за период), справочная информация и остатки

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

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

28000 руб.

15.12.2021    19577    129    38    

85

SALE! 10%

Перенос данных из ERP 2 / КА 2 в ЗУП 3

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

Обработка позволяет не только перенести все документы, справочную информацию и начальные остатки из ERP 2 или КА 2 в ЗУП 3, но и организовать регулярный перенос данных между программами 1С:ERP 2 / КА 2 и 1С:ЗУП 3. Вы можете выбрать период отбора данных и установить фильтр по организациям, чтобы выгружать только необходимую информацию. Более того, перенос оперативно обновляется при выходе новых релизов программы 1С, так что вы всегда будете иметь самую актуальную версию обработки.

48278 43450 руб.

03.12.2020    33731    79    57    

76

SALE! 10%

Перенос данных из УПП 1.3 / КА 1.1 в БП 3.0

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

Перенос данных из УПП 1.3 в БП 3.0 (или из КА 1.1 в БП 3.0). Переносятся документы, начальные остатки и вся справочная информация. Есть фильтр по организации и множество других параметров выгрузки. Поддерживается несколько сценариев работы: как первичный полный перенос, так и перенос только новых документов. Перенос данных возможен в 1С: Бухгалтерию 3.0 версии ПРОФ, КОРП или базовую. Переход с "1С: Управление производственным предприятием 1.3" / "1С:Комплексная автоматизация 1.1" на "1С:Бухгалтерия предприятия 3.0" с помощью наших правил конвертации будет максимально комфортным!

43889 39500 руб.

25.02.2015    167992    286    240    

370

Перенос данных из УТ 10.3 в УТ 11.5. Переносятся документы (обороты за период), справочная информация и остатки

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

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

28000 руб.

23.07.2020    45356    193    63    

150

SALE! 10%

Перенос данных из УПП 1.3 в ЗУП 3.1 или из КА 1.1 в ЗУП 3.1

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

Перенос кадровых и расчетных данных и справочной информации из "1С:Комплексная автоматизация, ред. 1.1" или "1С:Управление производственным предприятием, ред.1.3" в "1С:Зарплата и управление персоналом", ред. 3.1. Правила позволяют перенести кадровые данные сотрудников за весь период ведения учета в КА 1.1 / УПП 1.3 и расчетные данные за выбранный период (минимально необходимый - 2 года). Позволяют осуществить переход на ведение учета зарплаты и кадров в программе 1С:Зарплата и управление персоналом, ред. 3.1.

50722 45650 руб.

29.10.2018    53952    52    97    

55

Перенос данных из Парус 10 в ЗГУ ред.3

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

Обработка позволяет перенести кадровую информацию и данные по заработной плате, фактических удержаниях, НДФЛ, вычетах, страховых взносах из базы Парус 10 учреждений в конфигурацию 1С:Зарплата и кадры государственного учреждения ред. 3 (ЗГУ) и начать с ней работать с любого месяца года.

60000 руб.

05.10.2022    9021    8    8    

10
Комментарии
В избранное Подписаться на ответы Сортировка: Древо развёрнутое
Свернуть все
1. Yashazz 4690 03.10.13 12:22 Сейчас в теме
Абсолютно бесполезная вещь.
Открою страшный секрет: валидность с точки зрения утилит msxml и с точки зрения 1С - совершенно разные вещи. Будьте готовы к тому, что файл, признанный валидным, не сработает, вызовет вылетание платформы, просто никак не прочитается и прочая. Аналогично, валидность xsd-схемы как таковой для большинства нормальных приложений и для 1С - разная. Многие схемы просто не грузятся, причём 1С ничего вообще не сообщает - тихо игнорит и всё. Фабрика может не скушать xsd, xml может "не подойти", хоть его 100% подгоняй, и прочее.
Например, полезнейшая штука построения xsd по имеющемуся файлу xml выдаёт схему, которую легко читают и понимают все, кроме 1С.

Это я к чему - имея дело с xml-механикой 1С, не полагайтесь на НЕ-1Сные фичи.
корум; +1 Ответить
2. andrewks 1367 03.10.13 12:43 Сейчас в теме
(1) Yashazz, собственно, я и не позиционировал обработку как проверялку для закачки файлов парсером 1С.

обработка делает ровно то, что и заявлено - проверяет файл на соответствие стандарту XML и приложенной схеме XSD.
лично я очень часто использую этот функционал при:
1. написании и отладки кода по формированию/выгрузке xml-файлов для сторонних приложений/сервисов, когда структура оговорена схемой
2. после отладки - внедряю в код для выгрузки автоматическую проверку выгруженного файла по схеме. позволяет сэкономить время, укорачивая цепочку - многие ошибки сразу показываются при выгрузке, а не после закачки на какой-нибудь портал.

P.S. открою секрет - абсолютно бесполезных вещей не бывает! бывают бесполезные для кого-то
adva; Светлый ум; +2 Ответить
4. Yashazz 4690 03.10.13 13:21 Сейчас в теме
(2),(3) А, ну "тады да". Тогда вопросов больше не имею. Если 1С-ные грабли известны, и сторонний функционал взят нарочно, то, может, это и правда best practice.
3. andrewks 1367 03.10.13 13:10 Сейчас в теме
(1) Yashazz, поскольку форум проглючил, и сообщение не сохранилось, повторю кратко:

а сторонний функционал (msxml) был выбран именно потому, что я довольно пообщался с функционалом 1С касательно xml/xsd, чтобы опасаться его использовать в этом вопросе
корум; starik-2005; +2 Ответить
5. CagoBHuK 32 09.10.13 14:33 Сейчас в теме
Всем: пользуйтесь Altova XML Spy.
6. andrewks 1367 09.10.13 14:40 Сейчас в теме
(5) CagoBHuK, ничего, что он платный?
7. CagoBHuK 32 09.10.13 14:46 Сейчас в теме
(6) При желании можно найти и бесплатный аналог, и лекарство от жадности. А вообще нормальный программист найдет денег для того, чтобы купить себе хороший инструмент.
8. andrewks 1367 09.10.13 15:02 Сейчас в теме
(7) CagoBHuK,
А вообще нормальный программист найдет денег для того, чтобы купить себе хороший инструмент.

нормальный программист может также найти время на написание инструмента самому, не так ли?
kolibrik99; NAlex; starik-2005; +3 Ответить
9. CagoBHuK 32 09.10.13 15:31 Сейчас в теме
(8) Да, но сначала он задастся следующими вопросами:
  • Зачем изобретать велосипед?
  • Будет ли потраченное время стоить тех денег, которые придется заплатить за уже существующий инструмент?
10. andrewks 1367 09.10.13 16:42 Сейчас в теме
(9) CagoBHuK, я оценил, и решил, что быстрее и дешевле написать самому обработочку, юзающую msxml, и пользоваться. тем более, что больше от альтовы мне ничего не надо (кроме валидации). и даже решил поделиться с общественностью

раз в винде заложен данный функционал - почему бы им не воспользоваться? ну, а у кого есть лишние деньги - пусть покупают хоть альтову, хоть другое ПО - я ж не против.

только не пойму, какой смысл агитировать за покупку коммерческого ПО в камментах к бесплатному продукту
11. CagoBHuK 32 09.10.13 16:46 Сейчас в теме
(10) Я никого ни к чему не агитирую. Я специально сделал приписку, что при желании можно найти бесплатный продукт.
12. Ёпрст 1062 09.10.13 16:47 Сейчас в теме
Эээ.. а в штатном снеговике разве нет валидации по схеме ?
..
13. andrewks 1367 09.10.13 17:06 Сейчас в теме
(12) Ёпрст, лично у меня не получилось это сделать со штатным функционалом. если есть реально рабочий пример - милости просим
14. Ёпрст 1062 09.10.13 18:09 Сейчас в теме
Я не проверял, мне лень, как то валидацию, в своих поделках повыкидывал, за ненадобностью.
starik-2005; +1 Ответить
15. sikuda 672 17.03.15 14:16 Сейчас в теме
Да чего-то Microsoft Validator это конечно лучше, чем от 1С но тоже есть непонятки. Altova тоже советую...
16. Yury1001 1469 31.03.15 16:31 Сейчас в теме
Спасибо, огромное, искал аж с ног сбился - декларант-алко не запускается, а файлы перед отправкой проверить хочется.
+1
17. Широкий 692 16.12.15 14:15 Сейчас в теме
Пытался проверить файл по схеме ЕГАИС:

==================================================================
16.12.2015 14:14:18: Начата проверка по схеме файла: C:\111.xml
Не удалось подключить схему: C:\ЕГАИС\xsd\WB_DOC_SINGLE_01.xsd
16.12.2015 14:14:18: Проверка завершена
============================================================­======
18. andrewks 1367 22.12.15 23:00 Сейчас в теме
(17) и что именно непонятно? написано же, что не смог подключить схему. значит, нужно проверить наличие файла схемы, а также его корректность
19. nikulin76 139 25.02.16 16:17 Сейчас в теме
На схемы от ЦБ тоже ругается
... Не удалось подключить схему: ...
RomanUzmov; +1 Ответить
20. RomanUzmov 40 15.03.16 19:19 Сейчас в теме
(19) nikulin76, Аналогичная ситуация
21. andrewks 1367 16.03.16 23:40 Сейчас в теме
(19) nikulin76, попробуйте такой вариант
Прикрепленные файлы:
ВалидацияXML_1.01.epf
22. EvgKo 31.10.16 21:57 Сейчас в теме
Добрый день!
При валидации ХМЛ-файла с помощью данной обработки выдается сообщение:

"Обнаружена ошибка:
Смещение = 612, строка = 8, позиция = 17, код ошибки: -1072898035
Описание ошибки: Элемент ''{http://fsrar.ru/WEGAIS/TTNSingle_v2}Identity'' используется, но не был объявлен в DTD и схеме."

В самой схеме "TTNSingle_v2" объявление "Identity" есть. Подскажите, в чем может быть проблема?
23. Rudakov_D 225 28.11.16 12:59 Сейчас в теме
У меня тоже выдала ошибку

28.11.2016 16:39:42: Начата проверка по схеме файла: D:\val\v8_D76D_7b.xml
Не удалось подключить схему: D:\val\TTNSingle_v2.XSD
28.11.2016 16:39:43: Проверка завершена
24. NAlex 6 18.01.17 17:49 Сейчас в теме
Собственно, опять же ошибка:
============================================================­======
18.01.2017 17:39:26: Начата проверка по схеме файла: C:\Users\abc\Desktop\0d13381f-79d8-430f-953d-fd4608fbc97e.xml
Не удалось подключить схему: W:\for_files\PledgeRegistry.xsd
18.01.2017 17:42:41: Проверка завершена
============================================================­======
несмотря на то, что Altova XMLSpy 2011 Enterprise Edition успешно валидировала этой файл Xml этой схеме Xsd.
В чем может быть проблема?
25. kauksi 212 30.05.17 13:54 Сейчас в теме
работающий вариант: кусок кода процедуры Проверка по схеме клиент

//Прочитаем схему
	Попытка
		xmldoc=Новый COMОбъект("MSXML2.DOMDocument.6.0");
	Исключение
		ВывестиСообщение("Не удалось создать объект DOM1Document (возможно, не установлен MSXML 6)",2);
		Схема=Неопределено;
		Возврат РезПроверки;
	КонецПопытки;
	
	xmldoc.async = false;  
	xmldoc.load(ИмяФайлаСхемы);

	Если (xmldoc.parseError.errorCode<>0) Тогда
       	// ошибки при проверке правильности
		ВывестиСообщение("При проверке по схеме выявлены ошибки!",Куда,Форматировать);
		Если ВыводитьВсеОшибки Тогда
			Для каждого parseError из xmldoc.parseError.AllErrors  Цикл
				ВывестиОшибкуРазбораХМЛ(parseError.reason,Куда,Форматировать);
			КонецЦикла;
		Иначе
			ВывестиОшибкуРазбораХМЛ(xmldoc.parseError.reason,Куда,Форматировать);
		КонецЕсли;
	КонецЕсли;

	
	// Подключим ее
	Попытка
		Схема=Новый COMОбъект("MSXML2.XMLSchemaCache.6.0");
	Исключение
		ВывестиСообщение("Не удалось создать объект XMLSchemaCache (возможно, не установлен MSXML 6)",2);
		Возврат РезПроверки;
	КонецПопытки;
	
	Попытка
		Схема.addCollection(xmldoc.namespaces);
		//Схема.add(,ИмяФайлаСхемы);
	Исключение
		ВывестиСообщение("Не удалось подключить схему: "+ИмяФайлаСхемы,2);
		Схема=Неопределено;
		Возврат РезПроверки;
	КонецПопытки;
Показать
Прикрепленные файлы:
ВалидацияXML_1.01.epf
26. kauksi 212 30.05.17 13:59 Сейчас в теме
однако выводимая ошибка не очень информативна

Обнаружена ошибка:
Смещение = 215, строка = 2, позиция = 193, код ошибки: -1072897676
Описание ошибки: Значение не может быть пустым

понятно что какой то элемент не заполнен, а вот какой не говорит, собака
27. anton448 88 20.07.17 11:56 Сейчас в теме
Добрый день, andrewks

Помогите пжл. разобраться в такой проблеме.

Скачал последнюю вашу обработку с рабочим кодом, файл проверяется по схеме, но при этом всегда сообщается, что "Файл успешно прошёл проверку по схеме!", хотя я файл специально "ломаю", чтобы получить ошибку при проверке....

Т.е.в коде система почему то не проваливается в условие

Если (ДОМ.parseError.errorCode<>0) Тогда
		// ошибки при проверке правильности
		ВывестиСообщение("При проверке по схеме выявлены ошибки!",Куда,Форматировать);
		Если ВыводитьВсеОшибки Тогда
			Для каждого parseError из ДОМ.parseError.AllErrors  Цикл
				ВывестиОшибкуРазбораХМЛ(parseError,Куда,Форматировать);
			КонецЦикла;
		Иначе
			ВывестиОшибкуРазбораХМЛ(ДОМ.parseError,Куда,Форматировать);
		КонецЕсли;
	Иначе
		ВывестиСообщение("Файл успешно прошёл проверку по схеме!",Куда,Форматировать);
		РезПроверки=Истина;
	КонецЕсли;
Показать


Получается, что "ДОМ.parseError.errorCode" всегда равно 0, хотя ошибки есть 100%

Во вложении сама обработка, файл, который нужно проверить и схема (для наглядности)

Спасибо.
Прикрепленные файлы:
ВалидацияXML_1.01_2 (рабочий вариант).epf
2017-07-19-18-58-00 WayBill-1-2017-07-19.xml
v8_2108_779 - это ТТН версия 2.xsd
Andrekaa; megatrend; +2 Ответить
28. tezdal 29 18.10.18 16:45 Сейчас в теме
18.10.2018 17:43:17: Начата проверка по схеме файла: D:\debug\R2_3019021828_098_18102018_7b85db23-df15-494d-b8b2-819f1e829034.xml
Не удалось подключить схему: D:\12-o.xsd
Описание ошибки: {ВнешняяОбработка.ВалидацияXML.Форма.Форма.Форма(171)}: Ошибка при вызове метода контекста (add): Типы не совпадают (1)
18.10.2018 17:43:19: Проверка завершена

Схема.add("",ИмяФайлаСхемы); решило эту проблему.
Andrekaa; +1 Ответить
Оставьте свое сообщение