Ошибка при установке значения атрибута контекста value

Содержание:

1.       Ошибка при установке значения атрибута контекста

2.       Ошибка при получении значения атрибута контекста

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

1.    Ошибка при установке значения атрибута контекста

Ошибка при установке значения атрибута контекста говорит нам о невозможности присвоить выбранное значение определенному атрибуту информационного объекта. Вызвано это либо несовпадением типа атрибута и присваиваемого ей значения, отсутствием возможности присвоить значение выбранному атрибуту, так как его можно только читать, но не записывать в него, отсутствием прав у текущего пользователя на запись значений в данный атрибут. Например, в реквизит «ДатаДокумента» с типом «Дата» пытаемся записать строку, в реквизит с типом данных ссылки на документ пытаемся записать не ссылку, а объект, полученный по ссылке, что невозможно из-за несоответствия типов, что приводит к ошибке установки значения атрибута. 

Другой пример – проходя циклом выборку запроса, пытаемся в колонку выборки записать значение, что невозможно, так как значения выборки запроса можно только считывать, а для того, чтобы можно было полученные из запроса данные изменять в коде, нужно пользоваться не выборкой, а выгружать результат запроса в таблицу значений, в таком случае в цикле по ней можно будет менять значения в колонках, но только на значения, соответствующие типу колонки. Либо у пользователя, под которым выполняется код, нет прав на изменение даты документа, при попытке записать в данный реквизит новую дату, будет выведено сообщение об ошибке установке значения, но в причине будет указано отсутствие прав у пользователя.  

2.    Ошибка при получении значения атрибута контекста

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

При возникновении данных ошибок значения атрибута в 1Св первую очередь следует проверить существование атрибута, к которому обращаются, затем проверить совпадение типов значений атрибута и присваиваемого ему значения, затем уже проверить права на установку либо чтение значения. Проверить, является ли дело в правах либо дать права на действия с атрибутом, можно, установив привилегированный режим для совершения действия с данным атрибутом, прописав перед строчкой с ошибкой УстановитьПривилегированныйРежим(Истина), после строчки — УстановитьПривилегированныйРежим(Ложь).  

Специалист компании «Кодерлайн»

Александр Суворов

Heltarion

2 / 2 / 0

Регистрация: 21.11.2011

Сообщений: 57

1

02.12.2011, 11:18. Показов 9104. Ответов 11

Метки нет (Все метки)


Студворк — интернет-сервис помощи студентам

Добрый день!
Посмотрите пожалуйста. Есть в обработке таблица значений, в которую я выгружаю данные их XML, после этого я корректирую таблицу и хочу чтобы программа сохранила ее в новый документ эксель. Для этого я создал процедуру «Процедура СохранитьНажатие(Элемент) Экспорт». При сохранении выскакивает: «Ошибка при установке значения атрибута контекста (Value)». Насколько я понимаю, программе не нравится тип значения, который я передаю.
Переменные:

ТПП — «табличное поле правил», в ней уже занесены некотрые значения из XML
НоменклатураЗагрузки, НоменклатураБазы — имена столбцов ТПП
СтолбЗагр, СтолбБаз — столбцы в экселе

Код процедуры:

1C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
СтолбЗагр = 1;
СтолбБаз = 2;
 
Если ИнициализацияЭкселя() Тогда
      Книга = Excel.WorkBooks.Add();
      Sheet = Книга.Sheets(1);
    
      Для каждого стр из ТПП Цикл
              Sheet.Cells(стр,СтолбЗагр).Value=стр.НоменклатураЗагрузки;
              Sheet.Cells(стр,СтолбБаз).Value=стр.НоменклатураБазы;
      КонецЦикла;
 
      Попытка
              Книга.SaveAs("F:1CBaseВнешнии обработкиправила.xls");
      Исключение
              Сообщить(ОписаниеОшибки()+" Файл не сохранен!");
              Возврат;
      КонецПопытки;
КонецЕсли;
Сообщить("Готово");



0



308 / 308 / 1

Регистрация: 16.01.2011

Сообщений: 1,073

02.12.2011, 11:32

2

СохранитьНажатие(Элемент) это событие формы
в этой процедуре пропиши вызов другой процедуры, например СохранитьВЭксель();
саму же процедуру СохранитьВЭксель() добавь в модуль объекта и сделай её экспортной. Вставь свой код представленный выше.
обращение из формы будет ЭтотОбъект.СохранитьВЭксель();



1



2 / 2 / 0

Регистрация: 21.11.2011

Сообщений: 57

02.12.2011, 11:56

 [ТС]

3

СохранитьНажатие(Элемент) это событие формы
в этой процедуре пропиши вызов другой процедуры, например СохранитьВЭксель();
саму же процедуру СохранитьВЭксель() добавь в модуль объекта и сделай её экспортной. Вставь свой код представленный выше.
обращение из формы будет ЭтотОбъект.СохранитьВЭксель();

В МодулеОбъекта создал функцию «Процедура СохранитьВЭксель(ТПП) Экспорт»
Прописал в ней тотже код, что выше. В событии формы написал: ЭтотОбъект.СохранитьВЭксель(ТПП);
Выскочила ошибка: Ошибка при вызове метода контекста (Cells)
Что я нетак сделал?



0



308 / 308 / 1

Регистрация: 16.01.2011

Сообщений: 1,073

02.12.2011, 12:10

4

процедуру ИнициализацияЭкселя() тоже закинь в модуль объекта
СохранитьВЭксель(ТПП), параметр ТПП скорее всего не нужен



1



2 / 2 / 0

Регистрация: 21.11.2011

Сообщений: 57

02.12.2011, 12:19

 [ТС]

5

Да я именно так и сделал, просто забыл упомянуть, ТПП нужна в противном случае он не понимает что это за переменная

Добавлено через 4 минуты
Проблема вот в чем:
Sheet.Cells(стр,СтолбЗагр).Value=1;
Sheet.Cells(стр,СтолбБаз).Value=2;

Так работает, но если я поставлю
Sheet.Cells(стр,СтолбБаз).Value=стр.НоменклатураБазы;
Выдает ошибку «Ошибка при установке значения атрибута контекста (Value)».

Дело в том что «стр.НоменклатураБазы» — это справочник ссылка, если у нее текстовый тип то программа глотает и записывает.



0



19 / 18 / 1

Регистрация: 15.11.2011

Сообщений: 54

02.12.2011, 12:22

6

чет вы мудрено делаете.
У вас не правильно указывается адресс ячейки в cell. Если стр — это коллекция или массив записей, то он не может нести в себе номер ячейки.
Не знаком с 1C, но програмлю в Excel и делаю выгрузки из других систем.



1



2 / 2 / 0

Регистрация: 21.11.2011

Сообщений: 57

02.12.2011, 12:28

 [ТС]

7

В данный момент ему не нравится присваемое значение к ячейке экселя (если я правильно понимаю сообщение «Ошибка при установке значения атрибута контекста (Value)» )

Причем если тип значения строка, то он его получает без вопросо, если тип значения СправочникССсылка, то он руегается на «Ошибка при установке значения атрибута контекста (Value)».

Я просто не понимаю как обратиться к такому типу переменных чтобы получить значение типа строка.



0



19 / 18 / 1

Регистрация: 15.11.2011

Сообщений: 54

02.12.2011, 12:30

8

а принудительно все значения в текст перевести нельзя?



1



308 / 308 / 1

Регистрация: 16.01.2011

Сообщений: 1,073

02.12.2011, 12:30

9

стр.НоменклатураБазы.Наименование например



1



2 / 2 / 0

Регистрация: 21.11.2011

Сообщений: 57

02.12.2011, 12:32

 [ТС]

10

стр.НоменклатураБазы — это уже есть наименование интересующего меня поля (имя столбца), в некотрых случаях можно писать: стр.НоменклатураБазы.Значение, но это нетот случай

Добавлено через 56 секунд
Спасибо вам большое, вы меня на правильный путь направили, мне сейчас только понять как получить значение из данного элемента



0



308 / 308 / 1

Регистрация: 16.01.2011

Сообщений: 1,073

02.12.2011, 12:34

11

значение из Excel?



1



Heltarion

2 / 2 / 0

Регистрация: 21.11.2011

Сообщений: 57

02.12.2011, 12:43

 [ТС]

12

Рабочий код:

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
Функция ИнициализацияЭкселя()
 
    //Пытаемся подключиться к Excel
    Попытка
        Excel = новый COMОбъект("Excel.Application");
        Сообщить("=====> Загрузка производится через MS Excel...");
        Возврат Истина;
    Исключение
        Возврат Ложь                
    КонецПопытки;     
    
КонецФункции
 
 
Процедура СохранитьНажатие(Элемент) Экспорт
    СтолбЗагр = 1; // задаю номер столбца№1 в эксель
    СтолбБаз = 2;  // задаю номер столбца№2 в эксель
    
    Если ИнициализацияЭкселя() Тогда
        Книга = Excel.WorkBooks.Add(); // создал новый документ
        Sheet = Книга.Sheets(1);          // открыл страницу 1
   
// цикл для заполнения таблицы эксель данными из табличного поля (по двум полям)     
        Для каждого стр из ТПП Цикл
            Sheet.Cells(стр,СтолбЗагр).Value=стр.НоменклатураЗагрузки;
            Sheet.Cells(стр,СтолбБаз).Value=стр.НоменклатураБазы.Наименование;
        КонецЦикла;
 
//выполняю сохранение документа       
        Попытка
            Книга.SaveAs("F:1CBaseВнешнии обработкиправила12.xlsx");
        Исключение
            Сообщить(ОписаниеОшибки()+" Файл не сохранен!");
            Возврат;
        КонецПопытки;
    КонецЕсли;
    Книга.Application.Quit();
    Сообщить("Готово");
КонецПроцедуры



0



Попытка

       // Загрузка Microsoft Excel

       Состояние(«Загрузка Microsoft Excel…»);

       Excel = Новый COMОбъект(«Excel.Application»);

   Исключение

       Сообщить(«Ошибка при загрузке Microsoft Excel.» + Символы.ПС + ОписаниеОшибки(), СтатусСообщения.Внимание);

       Возврат;

   КонецПопытки;

   Excel.WorkBooks.Add();    

   
   row=1;

   Для Каждого Элемент Из Результат Цикл

       Excel.Cells(row, 1).Value = Элемент.Организация;

       Excel.Cells(row, 2).Value = Элемент.Субконто1;

       Excel.Cells(row, 3).Value = Элемент.Субконто2;

       Excel.Cells(row, 4).Value = Элемент.Счет;

       Excel.Cells(row, 5).Value = Элемент.СуммаОстатокДт;

       Excel.Cells(row, 6).Value = Элемент.СуммаОстатокКт;

       row = row+1;

   КонецЦикла;

Здравствуйте!

Задача: Передать из 1С в хранимую процедуру на MSSQLSERVER параметр табличного типа?

в С# вот так замечательно передается параметр табличного типа и все работает:

DataTable table = new DataTable(); //Далее заполняем таблицу, подключаемся SqlConnection connection1 = new SqlConnection(@»Data Source= …….

 SqlParameter p = new SqlParameter(«@Name», SqlDbType.Structured);
p.Value = table; //и ……..

В 1С вот так передаются обычные параметры:

Подключение = Новый COMОбъект(«ADODB.Connection»);

*******

*******

П1 = «Какое то значение для параметра обычных типов»;

Тип = «Числовое значение указывающее на тип»

СтрДл1 =  СтрДлина(П1);

P1 = Command.CreateParameter(«@Param», Тип, 1, СтрДл1, П1);
Command.Parameters.Append(P1);

Не могу найти какое значение нужно указать в качестве Type в Command.CreateParameter для 1С!

Или может причина в другом?

В ADO есть такой тип?

Может существует драгой подход?

указывал

 П1 = Command.CreateParameter();
                 П1.Name = «@Name»;
                 П1.Type = «SqlDbType.Structured»; //Именно в кавычках
                 П1.Value = table; // table — это ТаблицаЗначений 1С
Выдает ошибку:

Ошибка при установке значения атрибута контекста (Value)
                 П1.Value = table;

по причине:
Произошла исключительная ситуация (ADODB.Parameter): Аргументы имеют неверный тип, выходят за пределы допустимого диапазона или вступают в конфликт друг с другом.

В обоих случаях table заполнена одинаковыми данными

Передавать таблицу на сервер при помощи нескольких тысяч ИНСЕРТОВ накладно!

Заранее благодарю за помощь!


  • Изменено

    29 мая 2012 г. 14:34

Добрый день,
После подключения расширения4.89
e (и то же самое для 4.91e), при наличии в конфигурации БСП версии 2.4.6.78, при попыткевхода любого пользователя без административных прав возникает ошибка:

Платформа: 1С:Предприятие 8.3 (8.3.12.1685)

Ошибки:
———————————————————————————
26.04.2019 10:21:38
{Справочник.ВерсииРасширений.МодульМенеджера(130)}: Ошибка
при получении значения атрибута контекста (ВерсияРасширений)
ВерсияРасширений
= ПараметрыСеанса.ВерсияРасширений;
по причине:
{Справочник.ВерсииРасширений.МодульМенеджера(458)}: Ошибка
при вызове метода контекста (Записать)
Объект.Записать();
по причине:
Ошибка при выполнении обработчика — ‘ПередЗаписью’
по причине:
{Справочник.ИдентификаторыОбъектовРасширений.МодульМенеджера(107)}:
Ошибка при получении значения атрибута контекста (ВерсияРасширений)
Запрос.УстановитьПараметр(«ВерсияРасширений»,
ПараметрыСеанса.ВерсияРасширений);
по причине:
Попытка получения неинициализированного значения параметра
сеанса

Под полными правами вбазу заходит. Но при попытке открыть любой элемент справочника возникает ошибка:
{Справочник.ИдентификаторыОбъектовРасширений.МодульМенеджера(107)}:
Ошибка при получении значения атрибута контекста (ВерсияРасширений)
Запрос.УстановитьПараметр(«ВерсияРасширений»,
ПараметрыСеанса.ВерсияРасширений);
по причине:
{Справочник.ВерсииРасширений.МодульМенеджера(458)}: Ошибка
при вызове метода контекста (Записать)
Объект.Записать();
по причине:
Ошибка при выполнении обработчика — ‘ПередЗаписью’
по причине:
{Справочник.ИдентификаторыОбъектовРасширений.МодульМенеджера(107)}:
Ошибка при получении значения атрибута контекста (ВерсияРасширений)
Запрос.УстановитьПараметр(«ВерсияРасширений»,
ПараметрыСеанса.ВерсияРасширений);
по причине:
Попытка получения неинициализированного значения параметра
сеанса

Пришлось пока что отключатьрасширение через конфигуратор. Дальше попробовал удалить записи справочника
Версии расширений и РС Идентификаторы объектов версий расширений, после чего
запустить базу с параметром /С ЗапуститьОбновлениеИнформационнойБазы. Теперь в
базу заходит, но при попытке открыть элемент справочника следующая ошибка:

Ошибки:
———————————————————————————
26.04.2019 11:46:37
Переполнение стека встроенного языка на сервере
по причине:

Справочник.нсиКонтрагенты.Форма.ФормаЭлемента.Форма : 26 :
ВерсионированиеОбъектов.ПриСозданииНаСервере(ЭтотОбъект);
ОбщийМодуль.ВерсионированиеОбъектов.Модуль : 106 : Объект =
ОбщегоНазначения.ИдентификаторОбъектаМетаданных(ПолноеИмяМетаданных);
ОбщийМодуль.ОбщегоНазначения.Модуль : 3181 : Возврат
Справочники.ИдентификаторыОбъектовМетаданных.ИдентификаторОбъектаМетаданных(ОписаниеОбъектаМетаданных);
Справочник.ИдентификаторыОбъектовМетаданных.МодульМенеджера
: 612 : Возврат
СтандартныеПодсистемыПовтИсп.ИдентификаторОбъектаМетаданныхПоПолномуИмени(ПолноеИмяОбъектаМетаданных);
Инфо:

Платформа: 8.3.12.1685
Режим БД: клиент-серверный
Конфигурация. Название: 1С:MDM Управление нормативно справочной информацией, редакция 2.0 (2.0.4.1)
Конфигурация. Основной режим запуска: Управляемое приложение
Конфигурация. Вариант встроенного языка: Русский
Конфигурация. Режим совместимости: Версия8_3_10
Конфигурация. Версия БСП: 2.4.6.78
Инструменты разработчика. Версия: Портативные 4.89p
Инструменты разработчика. Объекты на сервере: Да
Инструменты разработчика. Серверный модуль: Да
Клиент. ОС: Windows x86 Microsoft Windows 7 version 6.1 Service Pack 1 (Build 7601)
Клиент. Приложение: Обычное приложение 32б
Клиент. От имени администратора Windows: Нет
Клиент. Текущий язык системы: ru
Сервер. ОС: Windows x86-64 Microsoft Windows 8.1 version 6.3  (Build 9600)

Добавлено (26.04.2019, 12:01)
———————————————
В общем, похоже, что несколько запусков обработки БСП ОбновлениеВспомогательныхДанных.epf помогло. Если ещё возникнут проблемы, напишу.

Понравилась статья? Поделить с друзьями:
  • Ошибка при установке киберпанк 2077 isdone dll
  • Ошибка при установке значения атрибута контекста sshhostkeyfingerprint
  • Ошибка при установке значения атрибута контекста numberformat
  • Ошибка при установке интернет цензора
  • Ошибка при установке значения атрибута контекста activeconnection