Форум программистов, компьютерный форум, киберфорум
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/4: Рейтинг темы: голосов - 4, средняя оценка - 5.00
1 / 1 / 0
Регистрация: 30.09.2019
Сообщений: 103

Обработка Xml в 1С

09.08.2021, 14:41. Показов 917. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!
Я создал внешнюю обработку LoadXml.epf для загрузки XML-файла в таблицу 1С Предприятия 8.3.
1C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
&НаКлиенте
Процедура ФайлПутьСтрокаНачалоВыбора()
    ДиалогВыбораФайла = Новый ДиалогВыбораФайла(РежимДиалогаВыбораФайла.Открытие);
    ДиалогВыбораФайла.ПолноеИмяФайла = ФайлПутьСтрока;
    Если ДиалогВыбораФайла.Выбрать() Тогда
        ФайлПутьСтрока = ДиалогВыбораФайла.ПолноеИмяФайла;
    Иначе
        Сообщить("Файл не выбран!");
    КонецЕсли;
КонецПроцедуры
 
 
&НаСервере
Процедура ЗагрузитьНаСервере(ФайлПутьСтрока)
    ЧтениеXML = Новый ЧтениеXML;
    ЧтениеXML.ОткрытьФайл(ФайлПутьСтрока);
    
    Построитель = Новый ПостроительDOM;
    Документ = Построитель.Прочитать(ЧтениеXML);
    
    Для каждого СтрокаDOM Из Документ.ПервыйДочерний.ДочерниеУзлы Цикл
        Если СтрокаDOM.ИмяУзла = "Table1" Тогда
            Строка = Отчеты.Извещения.Добавить();
            Для каждого ПолеDOM Из СтрокаDOM.ДочерниеУзлы Цикл
                Если ПолеDOM.ИмяУзла = "ntfNum" Тогда
                    Строка.НомерИзвещения = ПолеDOM.ТекстовоеСодержимое;
                КонецЕсли;
                Если ПолеDOM.ИмяУзла = "ntfLotNm" Тогда
                    Строка.НомерЛота = Число(ПолеDOM.ТекстовоеСодержимое);
                КонецЕсли;
                Если ПолеDOM.ИмяУзла = "ndPb" Тогда
                    СтроковаяДата =Лев(СтрЗаменить(СтрЗаменить(СтрЗаменить(СтрЗаменить
                    (ПолеDOM.ТекстовоеСодержимое, "-", ""), ":", ""), "Т", ""), ".", ""), 14);
                    Строка.ДатаПубликация = Дата(СтроковаяДата);
                КонецЕсли;
                Если ПолеDOM.ИмяУзла = "ntfPrc" Тогда
                    Строка.МаксимальнаяЦенаКонтракта = ПолеDOM.ТекстовоеСодержимое;
                КонецЕсли; 
                Если ПолеDOM.ИмяУзла = "ntfReg" Тогда
                    Строка.Субъект = ПолеDOM.ТекстовоеСодержимое;
                КонецЕсли;
                Если ПолеDOM.ИмяУзла = "ntfZCmr" Тогда
                    Строка.Заказчик = ПолеDOM.ТекстовоеСодержимое;
                КонецЕсли;
                Если ПолеDOM.ИмяУзла = "fncNum" Тогда
                    Строка.ИсточникФинансирования = ПолеDOM.ТекстовоеСодержимое;
                КонецЕсли;
                Если ПолеDOM.ИмяУзла = "lotStgName" Тогда
                    Строка.Статус = ПолеDOM.ТекстовоеСодержимое;
                КонецЕсли;
                Если ПолеDOM.ИмяУзла = "href" Тогда
                    Строка.Ссылка = ПолеDOM.ТекстовоеСодержимое;
                КонецЕсли;
            КонецЦикла;
        КонецЕсли;
    КонецЦикла
КонецПроцедуры
 
 
&НаКлиенте
Процедура Загрузить(Команда)
    ЗагрузитьНаСервере(ФайлПутьСтрока);
КонецПроцедуры
Выдаёт ошибку:
1C
1
2
{ВнешняяОбработка.LoadXml.Форма.Форма.Форма(24)}: Метод объекта не обнаружен (Добавить)
            Строка = Отчеты.Извещения.Добавить();
Подскажите пожалуйста, как её исправить?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
09.08.2021, 14:41
Ответы с готовыми решениями:

Обработка структуры и содержимого текста отличного от XML средствами XML
Есть текст, в котором есть структура и ключевые символы придуманные какими-нибудь программистами для своего проекта. Т.е. свой язык....

обработка xml
- вот файл http://www.borsellino.ru/inet-mag.xml категории вот так выглядят - <category id="100" parentId="1">Женские...

обработка xml
в товарной позиции есть набор параметров <param name="Вендор">Doc Johnson, США</param> <param...

4
61 / 39 / 24
Регистрация: 24.09.2017
Сообщений: 170
09.08.2021, 19:02
Перед Циклами:
1C
1
2
МойОтчет=Отчеты.Извещения.Создать();
// Извещения - это должно быть имя отчета
Свою строку заменить
1C
1
2
3
//Строка = Отчеты.Извещения.Добавить();
Строка=МойОтчет.Извещения.Добавить();
// Извещения - это должно быть имя табличной части отчета
Извещения - это у тебя имя табличной части отчета и имя самого отчета? Так делать нельзя. Имя отчета и имя реквизитов должны отличаться
0
1 / 1 / 0
Регистрация: 30.09.2019
Сообщений: 103
09.08.2021, 19:57  [ТС]
Теперь сейчас выдаёт ошибку:
1C
1
2
{ВнешняяОбработка.LoadXml.Форма.Форма.Форма(26)}: Поле объекта не обнаружено (Извещения)
            Строка = Отчет.Извещения.Добавить();
Мой код:
1C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
&НаКлиенте
Процедура ФайлПутьСтрокаНачалоВыбора()
    ДиалогВыбораФайла = Новый ДиалогВыбораФайла(РежимДиалогаВыбораФайла.Открытие);
    ДиалогВыбораФайла.ПолноеИмяФайла = ФайлПутьСтрока;
    Если ДиалогВыбораФайла.Выбрать() Тогда
        ФайлПутьСтрока = ДиалогВыбораФайла.ПолноеИмяФайла;
    Иначе
        Сообщить("Файл не выбран!");
    КонецЕсли;
КонецПроцедуры
 
 
&НаСервере
Процедура ЗагрузитьНаСервере(ФайлПутьСтрока)
    Отчет = Отчеты.Извещения.Создать();
    
    ЧтениеXML = Новый ЧтениеXML;
    ЧтениеXML.ОткрытьФайл(ФайлПутьСтрока);
    
    ПостроительDOM = Новый ПостроительDOM;
    ДокументDOM = ПостроительDOM.Прочитать(ЧтениеXML);
    
    Для каждого СтрокаDOM Из ДокументDOM.ПервыйДочерний.ДочерниеУзлы Цикл
        Если СтрокаDOM.ИмяУзла = "Table1" Тогда
            Строка = Отчет.Извещения.Добавить();
            Для каждого ПолеDOM Из СтрокаDOM.ДочерниеУзлы Цикл
                Если ПолеDOM.ИмяУзла = "ntfNum" Тогда
                    Строка.НомерИзвещения = ПолеDOM.ТекстовоеСодержимое;
                КонецЕсли;
                Если ПолеDOM.ИмяУзла = "ntfLotNm" Тогда
                    Строка.НомерЛота = Число(ПолеDOM.ТекстовоеСодержимое);
                КонецЕсли;
                Если ПолеDOM.ИмяУзла = "ntfName" Тогда
                    Строка.Название = ПолеDOM.ТекстовоеСодержимое;
                КонецЕсли;
                Если ПолеDOM.ИмяУзла = "ndPb" Тогда
                    СтроковаяДата = Лев(СтрЗаменить(СтрЗаменить(СтрЗаменить(СтрЗаменить
                    (ПолеDOM.ТекстовоеСодержимое, "-", ""), ":", ""), "Т", ""), ".", ""), 14);
                    Строка.ДатаПубликация = Дата(СтроковаяДата);
                КонецЕсли;
                Если ПолеDOM.ИмяУзла = "ntfPrc" Тогда
                    Строка.МаксимальнаяЦенаКонтракта = ПолеDOM.ТекстовоеСодержимое;
                КонецЕсли; 
                Если ПолеDOM.ИмяУзла = "ntfReg" Тогда
                    Строка.Субъект = ПолеDOM.ТекстовоеСодержимое;
                КонецЕсли;
                Если ПолеDOM.ИмяУзла = "ntfZCmr" Тогда
                    Строка.Заказчик = ПолеDOM.ТекстовоеСодержимое;
                КонецЕсли;
                Если ПолеDOM.ИмяУзла = "fncNm" Тогда
                    Строка.ИсточникФинансирования = ПолеDOM.ТекстовоеСодержимое;
                КонецЕсли;
                Если ПолеDOM.ИмяУзла = "lotStgName" Тогда
                    Строка.Статус = ПолеDOM.ТекстовоеСодержимое;
                КонецЕсли;
                Если ПолеDOM.ИмяУзла = "href" Тогда
                    Строка.Ссылка = ПолеDOM.ТекстовоеСодержимое;
                КонецЕсли;
            КонецЦикла;
        КонецЕсли;
    КонецЦикла;
КонецПроцедуры
 
 
&НаКлиенте
Процедура Загрузить(Команда)
    ЗагрузитьНаСервере(ФайлПутьСтрока);
КонецПроцедуры
0
Модератор
Эксперт 1С
 Аватар для Dethmontt
4032 / 2977 / 594
Регистрация: 10.03.2011
Сообщений: 11,701
Записей в блоге: 1
10.08.2021, 01:18
Цитата Сообщение от AndreiSchreider Посмотреть сообщение
Поле объекта не обнаружено (Извещения)
Нет у отчета табличной части с именем Извещения, некуда добавлять твои строки
0
1 / 1 / 0
Регистрация: 30.09.2019
Сообщений: 103
10.08.2021, 12:51  [ТС]
Понятно.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
10.08.2021, 12:51
Помогаю со студенческими работами здесь

Обработка xml
Доброго времени суток. Необходимо отправить в БД лист стрингов. Обработка xml в процедуре БД: @codes xml ... DECLARE cur CURSOR FOR ...

Обработка XML
Привет! Не могу понять не получается объект после обработки XML строки: $resp = <<<XML <?xml version='1.0'...

Обработка XML
Есть файл XML заказов размером около 20 Мб с примерной структурой <catalog date="2020-05-05 17:00"> <orders> ...

Обработка Xml
Здравствуйте, есть проблема при парсинге Xml файла при помощи класса XmlTextReader ругается на одиночные - "&" в файле Xmk,...

Обработка XML в Delphi
Допусти есть какой-то XML, из узлов которого надо взять значения атрибутов и записать в переменные. Как бы это сделать? Использую Rad...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru