Удаление недопустимых символов в существующем файле XML (управляемые формы)

25.09.17

База данных - Чистка данных

КракозяL9;бры (крякозяL9;бры) — бессмысленный с точки зрения читателя набор символов, чаще всего получаемый на компьютере в результате неправильного перекодирования осмысленного текста. Если (не)осмысленные пользователи (не)осмысленно ввели такой текст в наименование например номенклатуры - получим некоторые проблемы при обменах xml.

Скачать исходный код

Наименование Файл Версия Размер
Удаление недопустимых символов в существующем файле XML (управляемые формы):
.epf 6,33Kb
98
.epf 6,33Kb 98 Скачать

Постановка задачи:

При загрузке такого файла к примеру обработкой Универсальный обмен данными в формате XML мы получим сообщение:

Ошибка при загрузке данных: {Обработка.УниверсальныйОбменДаннымиXML.МодульОбъекта(12257)}: Ошибка при вызове метода контекста (Прочитать): Ошибка разбора XML:  - [2444,36021]
Фатальная ошибка: 
PCDATA invalid Char value 2

Программисты 8.х видимо наступали на эти грабли, поэтому в каждой типовой конфигурации аж несколько раз встречается экспортная функция УдалитьНедопустимыеСимволыXML(Строка).

И при экспорте в xml символы такие удаляют.

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

Поэтому при переходе с 7.7 на 8.3 вас может ждать нежданчик.

Особенно это приятно, когда сам файл размером в 500 Мб.

Решение:

Слету не нашел ничего похожего ни для 1С, ни для PC, не считая могучих пакетов для обработки xml.

Внешняя обработка в 1С, которая убирает некорректные символы из файла xml и записывает его с новым названием, не перезаписывая старый..

Порядок работы:

Открываем обработку в 1С.

Нажимаем кнопку «Выполнить»

Выбираем файл для обработки

См. принтскрины

Требования к запуску обработки:

Обработка предназначена для использования с актуальными типовыми конфигурациями на управляемых формах.

Также возможна адаптация отчета под любую имеющуюся у пользователя типовую или нетиповую конфигурацию. 

Установка и использование обработки:

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

 

         Поддержка отчета, лицензирование:

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

       

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

Если вы не представляете: что такое 1С Предприятие,  файл, xml и зачем вам нужна эта кухня.

Если физиологические, моральные, религиозные или другие причины не позволяют вам заполнять справочники, документы, настраивать отчеты 1С и запускать обработки.

А платить вы за это не будете так как программист с десятилетним стажем.

Закройте эту страницу не продолжая чтения дальше.

Для адекватных людей:
Если оно есть у вас или предложения по улучшению - пишите.
Код открыт - дорабатывайте по себя как хотите.

PCDATA invalid Char value 2 XML Универсальный обмен данными в формате XML

См. также

Удаление данных с отбором и построением дерева ссылок в базах 1С 8.1-8.3 УТ 10.3./11, БП 2/3, ЗУП 2.5/3, КА 1.1/2, УНФ 1.6/3.0

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

Данные обработки помогут Вам легко и, главное быстро, выполнить удаление любых данных в Ваших базах 1С на платформах 8.1-8.3. Обработки помогут легко просмотреть связи ссылок в виде дерева, выбрать что удалять, а что нет, используя любые отборы. Это позволит уменьшить объем лишней и не нужной информации в справочниках и документах, планах видов характеристик и др. объектах и облегчит работу с данными пользователям и Вам. Понятное расположение команд и настроек, в сочетании с описанием и справкой, еще упростят процесс. (Обновление от 04.10.2023, версия 4.2)

9600 руб.

22.02.2013    136243    249    144    

418

Универсальное выборочное удаление данных из базы 1С (любые конфигурации на упр.формах: БП 3.0, УТ 11, КА 2, ERP, УНФ, ЗУП 3, Розница и т.д.)

Чистка данных Платформа 1С v8.3 Управляемые формы 1С:Розница 2 1С:Управление нашей фирмой 1.6 1С:ERP Управление предприятием 2 1С:Зарплата и кадры государственного учреждения 3 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Зарплата и Управление Персоналом 3.x Платные (руб)

Обработка позволяет удобно выборочно удалить данные из базы 1С. Это могут быть как неиспользуемые элементы справочников, так и неактуальные организации. При этом есть возможность провести анализ пересечений документов с другими организациями и таким образом уберечься от того, что при удалении обороты по другой организации изменятся.

3350 руб.

28.11.2019    24490    49    16    

62

SALE! 10%

Выборочное удаление организаций из баз (управляемые формы), с удалением всех ссылающихся на эти организации данных

Чистка данных Платформа 1С v8.3 Управляемые формы Конфигурации 1cv8 Платные (руб)

Позволяет удалить организации из любых программ на управляемых формах (БП 3.0, УТ 11, КА 2, ERP 2, ЗУП 3.0, УНФ, Розница 2.0 и пр.). Главное требование - программа должна содержать справочник "Организации". Реализован самый быстрый алгоритм непосредственного удаления объектов. Работает даже на базах большого размера. Для ускорения работы алгоритма не запускается проверка контроля ссылочной целостности. Проверку учета можно запустить отдельно с помощью дополнительной обработки. Необходимо перед удалением самостоятельно проверить базу на наличие перекрестных ссылок разных организаций в одном документе. Эту дополнительную обработку проверки перекрестных ссылок по запросу предоставляем бесплатно нашим покупателям.

3980 3582 руб.

16.03.2015    114081    182    77    

218

Замена Номенклатуры+Характеристики

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

Настраиваемая обработка, позволяющая заменить пару: Номенклатура+Характеристика в документах, их движениях и независимых регистрах сведений. Без перепроведения. Поможет, если вы по каким-то причинам решили отказаться от характеристик

3600 руб.

04.08.2015    41227    89    70    

50

Удаление битых ссылок 1С в базе без монопольного режима

Чистка данных Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

Если в вашей информационной базе крутится очень много данных, или база должна быть доступна 24/7 (как в моем случае), или же вы боитесь запускать тестирование и исправление, НО существует потребность удалить битые ссылки, тогда эта обработка сможет Вам помочь. Обработка выявляет битые ссылки как в самих объектах метаданных, так и в их табличных частях(!), а так же может их удалить.

2400 руб.

23.08.2021    9306    15    3    

20

Очистка регистров сведений от записей по помеченным на удаление элементам

Чистка данных Платформа 1С v8.3 Конфигурации 1cv8 Платные (руб)

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

1200 руб.

21.01.2022    7175    5    6    

9

Очистка кэша 1С. Исполнитель

Чистка данных Инструментарий разработчика Платформа 1С v8.3 Абонемент ($m)

Очередная вариативная очистка кэша 1С с помощью Исполнителя 3.0.2.2.

1 стартмани

25.10.2023    4638    4    SerVer1C    25    

22

Очистка регистра накопления. Очистка регистра сведений.

Чистка данных Платформа 1С v8.3 Управляемые формы Платформа 1C v8.2 Конфигурации 1cv8 Бесплатно (free)

ВАЖНО!!! Очистку регистров накопления и регистров сведений рекомендуется делать пользователям со знанием дела и с осознанием последствий! Обработка поможет быстро очистить выбранный регистр. Делаю данную обработку в первую очередь для себя, т.к. были случаи, когда нужно было очищать регистры, а делать красиво и удобно времени не было.

06.02.2023    13129    875    Neiron_1C    15    

18
Комментарии
Подписаться на ответы Инфостарт бот Сортировка: Древо развёрнутое
Свернуть все
1. zekrus 151 27.09.17 07:51 Сейчас в теме
Доброе утро!
Тема весьма актуальная.
Учитывая источники информации вводимые в справочники (копипаст).
С уважением
2. user918459 17.02.18 22:42 Сейчас в теме
Добрый день!
Подскажите, пожалуйста, как можно получить эту обработку Удаление недопустимых символов в существующем файле XML.
Виктор
3. WKBAPKA 214 21.11.18 10:28 Сейчас в теме
Спасибо, пригодилась.
Столкнулся с такой проблемой при переносе с 7.7 на 8
4. Светлый ум 406 06.04.20 11:21 Сейчас в теме
Простенько и со вкусом +1

Прикрутил в свой механизм: пригодилось.
5. Светлый ум 406 07.04.20 20:33 Сейчас в теме
(4) Добавил получение атрибута XML из строки в вашей функции:

ЧтениеXML.УстановитьСтроку(стрСтрока);	
Xml_Версия      = "";
Пока ЧтениеXML.Прочитать() Цикл
      Xml_Версия = ЧтениеXML.ЛокальноеИмя;
КонецЦикла;
6. a_l_e_xj 24 11.05.21 18:04 Сейчас в теме
Для тех кто хочет скачать:
в данной обработке всего 18 строк (вместе с пустыми), она даже не сообщает были недопустимые символы или нет.
Нет выбора кодировки. Нет никаких ухищрений для работы с большими файлами.
Обработка заработает только в стандартных 1С конфигурациях.
И за это 2 стартмани.

Для проверки недопустимых символов есть метод в платформе:
НайтиНедопустимыеСимволыXML(Стр);
т.е. просто перебирайте строки файла и проверяйте этим методом и не тратьте свои денежки.
7. capitan 2472 12.05.21 09:13 Сейчас в теме
(6)Не понял сути претензии.
Если было бы 100500 строк и делало бы то же самое, то все гуд ?
8. пользователь 21.02.22 23:48
Сообщение было скрыто модератором.
...
Оставьте свое сообщение