У вас "Ошибка преобразования данных XML" или "Error transforming XML data"? Решение

01.11.21

Задачи пользователя - Корректировка данных

Рассмотрим варианты возникновения данной ошибки и рассмотрим способ решения, одной из причин.

Скачать файл

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

Наименование По подписке [?] Купить один файл
Поиск и устранение ошибки "Ошибка преобразования данных XML"
.epf 8,77Kb ver:0.3
31
31 Скачать (2 SM) Купить за 2 150 руб.

Пожалуй, каждый, кто использует РИБ обмен, однажды получал "письмо счастья" от бота или же получал подобное сообщение об ошибке при ручном обмене "Ошибка преобразования данных XML" или на английском языке "Error transforming XML data". Обмен встал, что же делать?

Для начала, давайте рассмотрим варианты причин, которые могли привести к данной проблеме:

  1. Наш любимый кеш, хоть в данном случае редко он виновник, но с него стоит начать в решении проблемы;
  2. Не совпадающие метаданные (Например центральная база была обновлена, а изменения не доехали и/или узел считает что он уже обновлен, тут как раз часто помогает очистка кеша и повторный обмен);
  3. И наконец проблема, которой и посвящена данная публикация - повреждение значений реквизитов, у которых тип "Хранилище значения". Данная проблема чаще всего возникает при резком отключении компьютера во время записи объектов и прочих случаях (предположительно, хранилище значения, хранится отдельно и записывается в базу, после записи основного объекта, в основном, эти проблемы возникают в файловых базах).

Как же решить проблему в пункте №3?

Варианты решения три (от худшего к лучшему):

  1. Удалить регистрацию всех данных. Данный способ очень вредный, так как теряется кучу полезных данных вместе с поврежденными;
  2. Открыть XML файл в удобном текстовом редакторе и искать аномалии. После их нахождения, можно либо полностью удалить передачу поврежденного объекта или исправить поломанное хранилище значения;
  3. Возложить всю работу на обработку.

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

Как работает обработка?

  1. Указываем план обмена и узел, на котором зарегистрированы данные (в подчиненном узле, это узел центральной базы)
  2. Проходит по дереву метаданных и составляет базу видов объектов и их реквизитов типа "ХранилищеЗначения";
  3. Проверяет, входит ли данный объект в состав обмениваемых объектов
  4. Составляет запросы по найденным объектам с подверженными к повреждению реквизитами, выбираются ТОЛЬКО зарегистрированные объекты на выбранном узле
  5. Выбрав поля объектов, значения которого, подвержены риску повреждения, в цикле проверяем целостность данных
  6. Если повреждение обнаружено, получаем объект и записываем в хранилище значения "Неопределено"
  7. Выполняем обмен и идем пить любимые напитки!

А как проверить, что значение, хранилища значения, повреждено?

С этим есть некоторые сложности, так как что при получении значения из поврежденного хранилища значений мы получаем "Неопределено", ровно тоже самое, если в хранилище значения, было помещено "Неопределено". В некоторых случаях, при получении значения возникают исключение, но не всегда. В итоге получилась такая проверка:

Функция ХранилищеЗначенияПовреждено(Хранилище)
	Результат = Ложь;
	Попытка
		Если ПустаяСтрока(СериализаторXDTO.XMLСтрока(Хранилище)) Тогда
			Результат = Истина;
		КонецЕсли;
	Исключение
		Результат = Истина;
	КонецПопытки;
	Возврат Результат;
КонецФункции

Получилась (почти) универсальная обработка, по поиску и исправлению поврежденных данных хранилища значения. В настоящий момент, обработка поддерживает следующие типы объектов:

  • Справочники (реквизиты, табличные части)
  • Документы (реквизиты, табличные части)
  • Регистры сведений (ресурсы, реквизиты)*
  • Регистры накопления (ресурсы, реквизиты)*
  • Планы видов характеристик (реквизиты, табличные части)

* - В измерениях регистра, не может быть реквизитов типа "ХранилищеЗначения"

Обратите внимание, обработка записывает в поврежденное хранилище значения, значение "Неопределено", некоторые объекты не ожидают такого рода данных и могут выдавать ошибки при открытии и пр. При желании, вы можете сами доработать обработку, чтобы в зависимости от объекта, у вас вставлялась ожидаемая объектом структура и пр. Так же обработка предоставляется "AS IS", так что делайте бэкапы, перед выполнением. Обработка может иметь ошибки, в случае нахождения оных - пишите.
Обработка разрабатывалась и тестировалась на платформе 8.3.10.2505 с конфигурацией 1С:Розница 2.2.5. Но обработка должна быть совместима с любыми конфигурациями на управляемых формах.

Ошибка преобразования данных XML Error transforming data не выполняется обмен РИБ

См. также

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

Перенос документов, начальных остатков и справочной информации из УПП 1.3 в ERP 2 | из УПП 1.3 в УТ 11 | из УПП в КА 2 | Правила конвертации (КД 2) | Более 360 предприятий выполнили переход с использованием этого продукта! | Сэкономьте время - используйте готовое решение для перехода! | Позволяет перенести из УПП 1.3 в ERP / УТ 11 / КА 2 всю возможную информацию | В переносе есть фильтр по организации и множество других опциональных параметров выгрузки | Есть несколько алгоритмов выгрузки остатков на выбор

55778 руб.

04.08.2015    173465    374    287    

401

SALE! 15%

Перенос данных 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 руб.

12.06.2017    148001    855    302    

450

Перенос данных 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    58429    267    75    

223

Перенос данных 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    27605    196    56    

151

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

Перенос данных из ERP в БП 3 | из КА 2 в БП 3 | из УТ 11 в БП 3 | из ЕРП в БП 3 | Сэкономьте время - используйте готовое решение для перехода! | Перенос разработан в формате КД 2 (правила конвертации данных) | Переносятся все возможные виды документов, начальных остатков и нормативно-справочная информация| Можно опционально выгружать каждую пару "номенклатура+характеристика" как отдельную номенклатуру | Есть выгрузка настроек счетов учета и зарплатных данных из ERP / КА 2 | Можно проверить на вашем сервере перед покупкой

55778 руб.

15.04.2019    75910    203    158    

142

Перенос данных 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 руб.

25.02.2015    174894    317    267    

387

Перенос данных 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    190622    622    534    

542
Оставьте свое сообщение