1с ошибка при вызове метода контекста записьжурналарегистрации

Обратно к инструкциям

Иногда возникает ситуация, когда журнал звонков перестает загружать новые записи истории звонков из АТС, и в журнале регистрации 1С можно обнаружить следующую ошибки:

Ошибка запуска регламентной задачи: {ОбщийМодуль.МИКО_стЗагрузкаИсторииЗвонков_v7.Модуль}:
Ошибка при вызове метода контекста (ЗаписьЖурналаРегистрации): Недопустимое значение параметра (параметр номер ‘1’)

Решение данной проблемы:

1. Проверьте не заблокировано ли приложение системы лицензирования mlworker.exe службами AppLocker, защитником Windows, любыми другими службами или брандмауэрами.

Расположение приложения:

%USERPROFILE%\AppData\Local\MIKO\bin\MIKO\mlworker.exe

Приложение устанавливается на сервере 1С:Предприятия.

%USERPROFILE% — директория пользователя, под которым запущена служба «сервер 1С:Предприятия» (rphost).

2. У пользователя, под которым запущена служба Агент сервера 1С:Предприятия, достаточно прав доступа на чтение и запись в директорию %USERPROFILE%\AppData\Local\MIKO

3. Попробуйте удалить приложение системы лицензирования mlworker.exe на сервере 1С:Предприятия, предварительно завершив процесс приложения.

4. Удалите содержимое каталога %USERPROFILE%\AppData\Local\MIKO.

5. Сбросьте все привязки лицензии от хоста по инструкции.

Обратно к инструкциям

ЗаписьЖурналаРегистрации ☑ 0

IF_THEN

10.11.09

13:34

Добрый день, ребята кто подскажет что я делаю не так. Из 8 ки по ОЛЕ соединяюсь с 7.7. в 7 ой базе создаю объект. Далее хочу в журнал 7ой базы записать событие создания объякта. Пишу База77.ЗаписьЖурналаРегистрации(«Создан новый объект»,»Refs»,»RefNew»,справочник77,2); справочник77   = База77.CreateObject(«Справочник.Номенклатура»);

1

ДенисЧ

10.11.09

13:35

не взлетит.

2

IF_THEN

10.11.09

13:47

ща турбо надув дам и взлетит!

3

dk

10.11.09

13:52

взлетит, если пнуть с подвывертом )

4

dk

10.11.09

13:58

EvalExpr и ExecuteBatch еще никто не отменял )))

5

IF_THEN

10.11.09

14:17

Щас протестю

6

IF_THEN

10.11.09

15:10

База77.EvalExpr(«НайденныйОбъект=СоздатьОбъект(«»Справочник.Договоры»»);»)

{(1)}: Ошибка при вызове метода контекста (EvalExpr): Произошла исключительная ситуация (1С:Предприятие): 1    НайденныйОбъект<<?>>=СоздатьОбъект(«Справочник.Договоры»);

Переменная не определена (НайденныйОбъект)

не подскажете почему ругается, синтаксис правильный же

7

Михей

10.11.09

15:12

(6) CreateObject?

8

IF_THEN

10.11.09

15:13

(7) смотри (0) надо взять ссылку на элемент 7 ки и подставить в процедуру регистрации события

9

dk

10.11.09

15:13

(6) неправильно идею понял

10

IF_THEN

10.11.09

15:14

(9) ммм, да? не подскажешь твою идею?

11

dk

10.11.09

15:14

(8) ЗначениеИзСтрокиВнутр(ЗначениеВстрокуВнутр())

+ двойные кавычки учесть

12

Шахид

10.11.09

15:15

(10) а может напрямую в mlg писать или режим разделенный?

13

IF_THEN

10.11.09

15:16

(11) ну да, тема так можно передать объект. Но я вот выполнил запись в журнал без передачи объекта,и чет в журнал нече не добавилось.

14

IF_THEN

10.11.09

15:16

(12) не напрямую не нужно писать

15

Шахид

10.11.09

15:17

(14) жаль. такая идея пропадает :)

16

dk

10.11.09

15:22

База77.ExecuteBatch(«ЗаписьЖурналаРегистрации(«»Создан новый объект»»,»»Refs»»,»»RefNew»»,ЗначениеИзСтрокиВнутр(«+База77.ЗначениеВстрокуВнутр(справочник77.ТекущийЭлемент())+»),2);»)

17

dk

10.11.09

15:23

База77.ExecuteBatch(«ЗаписьЖурналаРегистрации(«»Создан новый объект»»,»»Refs»»,»»RefNew»»,ЗначениеИзСтрокиВнутр(«»»+СтрЗаменить(База77.ЗначениеВстрокуВнутр(справочник77.ТекущийЭлемент(),»»»»,»»»»»»))+»»»),2);»);

или так ))

18

Шахид

10.11.09

15:24

ТекущийЭлемент() по оле вроде не летает?

19

dk

10.11.09

15:29

Кто сказал?

20

IF_THEN

10.11.09

15:29

(18) летает

21

dk

10.11.09

15:29

напрямую нет, но обернутый летает

22

IF_THEN

10.11.09

15:31

интересно а почему без объекта не записывается событие. в отладке показывает выполнение метода ExecuteBatch истина, а в списке журнала нече не появляется. Все фильтры выставлены по все да и период нормальный..

23

dk

10.11.09

15:37

(15) эта идея давно реализована, у меня в том числе )

24

IF_THEN

10.11.09

15:38

в общем просто журнал регистраций настроен так что регистрируе пока только вход и выход))) p.s. на демке тестю

dk спасибо за инфо

    Процедура ПрименитьПараметрыУчета(ПараметрыУчета, ИзмененыПараметрыСубконто = Ложь, Отказ = Ложь) Экспорт

        ПризнакиУчета             = ПолучитьСтруктуруПризнаковУчетаСубконто();

        ДействияИзмененияСубконто = ПолучитьДействияИзмененияСубконто(ПараметрыУчета); // Иерархическая коллекция: на первом уровне действия с субконто на каждом из счетов, на втором — действия с призаками учета.

        // Сгруппируем изменения по счетам, так как записывать будем именно счет

        СчетаКИзменению = ОбщегоНазначения.ВыгрузитьКолонку(ДействияИзмененияСубконто, «Счет», Истина);

        ДействияИзмененияСубконто.Индексы.Добавить(«Счет»);

        Отбор = Новый Структура(«Счет»);

        НачатьТранзакцию();

        Для Каждого Счет Из СчетаКИзменению Цикл

            Отбор.Счет = Счет;

            ДействияДляСчета = ДействияИзмененияСубконто.НайтиСтроки(Отбор);

            Объект = Счет.ПолучитьОбъект();

            ПротоколИзменений = Новый Массив;

            Для Каждого Действие Из ДействияДляСчета Цикл

                // Действие: -1 удалить; 0 — не менять; 1 — установить

                // Действия с видом субконто

                Если Действие.Действие = 1 Тогда

                    // Добавить субконто

                    Если Счет = ПланыСчетов.Хозрасчетный.РасчетыСПерсоналомПоОплатеТруда Тогда

                        ВидыСубконтоСтрока = Объект.ВидыСубконто.Вставить(0);

                    Иначе          

                        ВидыСубконтоСтрока = Объект.ВидыСубконто.Добавить();

                    КонецЕсли;

                    ВидыСубконтоСтрока.ВидСубконто = Действие.Субконто;

                    ДобавитьВПротоколИзменениеСубконто(ПротоколИзменений, ВидыСубконтоСтрока.ВидСубконто, Действие.Действие);

                Иначе

                    ВидыСубконтоСтрока = Объект.ВидыСубконто.Найти(Действие.Субконто, «ВидСубконто»);

                    Если ВидыСубконтоСтрока = Неопределено Тогда

                        Продолжить;

                    КонецЕсли;

                КонецЕсли;

                Если Действие.Действие = -1 Тогда

                    ДобавитьВПротоколИзменениеСубконто(ПротоколИзменений, ВидыСубконтоСтрока.ВидСубконто, Действие.Действие);

                    Объект.ВидыСубконто.Удалить(ВидыСубконтоСтрока);

                    Продолжить;

                КонецЕсли;

                // Действия с признаками учета

                Для Каждого ПризнакУчета Из ПризнакиУчета Цикл

                    ДействиеСПризнаком = Действие[ПризнакУчета.Ключ];

                    Если ДействиеСПризнаком = 1 Тогда

                        ЗначениеПризнака = Истина;

                    ИначеЕсли ДействиеСПризнаком = -1 Тогда

                        ЗначениеПризнака = Ложь;

                    Иначе

                        Продолжить;

                    КонецЕсли;

                    Если ВидыСубконтоСтрока[ПризнакУчета.Ключ] = ЗначениеПризнака Тогда

                        Продолжить;

                    КонецЕсли;

                    ВидыСубконтоСтрока[ПризнакУчета.Ключ] = ЗначениеПризнака;

                    ДобавитьВПротоколИзменениеПризнакаУчета(

                        ПротоколИзменений,

                        ВидыСубконтоСтрока.ВидСубконто,

                        ПризнакУчета.Значение,

                        ДействиеСПризнаком);

                КонецЦикла; // По признакам учета

            КонецЦикла; // По ДействияДляСчета

            Если Не Объект.Модифицированность() Тогда

                Продолжить;

            КонецЕсли;

            ПротоколИзмененийСтрокой = СтрСоединить(ПротоколИзменений, Символы.ПС);

            Попытка

                Объект.Записать();//ВОТ ТУТ ВАЛИТСЯ

            Исключение

                ОписаниеОшибки = ИнформацияОбОшибке();

                ОтменитьТранзакцию();

                Отказ = Истина;

                ШаблонТекста = НСтр(«ru = ‘Ошибка при записи счета [КодСчета]:

                    |[ОписаниеОшибки]

                    |Ошибка произошла при попытке выполнить следующие изменения:

                    |[ПротоколИзменений]'»);

                ПараметрыТекста = Новый Структура;

                ПараметрыТекста.Вставить(«КодСчета»,          Объект.Код);

                ПараметрыТекста.Вставить(«ПротоколИзменений», ПротоколИзмененийСтрокой);

                // В журнал регистрации выведем подробную информацию

                ПараметрыТекста.Вставить(«ОписаниеОшибки», ПодробноеПредставлениеОшибки(ОписаниеОшибки));

                Текст = СтроковыеФункцииКлиентСервер.ВставитьПараметрыВСтроку(ШаблонТекста, ПараметрыТекста);

                ЗаписьЖурналаРегистрации(

                    СобытиеЖурналаРегистрацииПараметрыУчета(),

                    УровеньЖурналаРегистрации.Ошибка,

                    Счет.Метаданные(),

                    Счет, // Данные

                    Текст);

                // Пользователю выведем краткое сообщение

                ШаблонТекста = НСтр(«ru = ‘Ошибка при записи счета [КодСчета]

                    |Подробности см. в Журнале регистрации.'»);

                Текст = СтроковыеФункцииКлиентСервер.ВставитьПараметрыВСтроку(ШаблонТекста, ПараметрыТекста);

                ОбщегоНазначенияКлиентСервер.СообщитьПользователю(Текст);

                Возврат;

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

            // Запишем в журнал регистрации подробную информацию об изменениях

            ЗаписьЖурналаРегистрации(

                СобытиеЖурналаРегистрацииПараметрыУчета(),

                УровеньЖурналаРегистрации.Информация,

                Счет.Метаданные(),

                Счет,

                ПротоколИзмененийСтрокой,

                РежимТранзакцииЗаписиЖурналаРегистрации.Транзакционная);

        КонецЦикла; // По СчетаКИзменению

        БухгалтерскийУчетПереопределяемый.УстановитьПараметрыУчетаРасчетовПоЗарплате(?(ПараметрыУчета.ВестиУчетПоРаботникам = 1, Ложь, Истина));

        БухгалтерскийУчетПереопределяемый.УстановитьУчетЗарплатыИКадровВоВнешнейПрограмме(?(ПараметрыУчета.УчетЗарплатыИКадровВоВнешнейПрограмме = 1, Истина, Ложь));

        БухгалтерскийУчетПереопределяемый.УстановитьНастройкиКадровогоУчета(ПараметрыУчета.КадровыйУчет, ?(ПараметрыУчета.УчетЗарплатыИКадровВоВнешнейПрограмме = 0, Истина, Ложь));

        ЗафиксироватьТранзакцию();

        ОбновитьПовторноИспользуемыеЗначения();

    КонецПроцедуры

Содержание:

  1. Для чего нужен метод ЗаписьЖурналаРегистрации?
  2. Параметры метода ЗаписьЖурналаРегистрации в системе конфигурации 1С

Для чего нужен метод ЗаписьЖурналаРегистрации?

Не все события, которые происходят в пользовательском режиме 1С автоматически фиксируется платформой. Поэтому бывает потребность сделать в 1С запись журнала регистрации. Для таких случаев можно использовать метод ЗаписьЖурналаРегистрации.

Глобальный контекст

Метод ЗаписьЖурналаРегистрации служит для фиксации события в журнал регистрации. Доступен на серверной части, в толстом клиенте и при внешнем соединении 1С. Обязательно должен быть заполнен параметр <ИмяСобытия>.

Параметры метода ЗаписьЖурналаРегистрации в системе конфигурации 1С

Метод ЗаписьЖурналаРегистрации. Параметр «ИмяСобытия»

ИмяСобытия – описывает содержание события (Рис.1). Обязателен для заполнения. Текст имени события не должен содержать символов «_$» и «$_».

Установим для первого параметра «ИмяСобытия» значение равное «Загрузка. Начало». В режиме конфигуратора в 1С запишем код (Рис. 1). В пользовательском режиме 1С выполним метод ЗаписьЖурналаРегистрации.

Журнал регистрации

Откроем журнал регистрации и посмотрим результат. В окне «Журнал регистрации» была сделана запись. В поле «Событие» было записано значение первого параметра метода ЗаписьЖурналаРегистрации.

Метод ЗаписьЖурналаРегистрации. Параметр «Уровень»

Уровень – описывает уровень важности события (Рис. 2). Не обязателен для заполнения.

Значения:

УровеньЖурналаРегистрации.Информация

УровеньЖурналаРегистрации.Ошибка

УровеньЖурналаРегистрации.Предупреждение

УровеньЖурналаРегистрации.Примечание Установим для параметра «Уровень» значения, приведенные на рисунке 2. В режиме конфигуратора в 1С запишем код (Рис. 1). В пользовательском режиме 1С выполним метод ЗаписьЖурналаРегистрации

Загрузка. Начало

Откроем журнал регистрации и посмотрим результат. В окне «Журнал регистрации» были сделаны записи. В каждой строке в первом поле в виде картинки отобразилось значение параметра «Уровень» метода ЗаписьЖурналаРегистрации.

В первой строке отобразилась картинка, для уровня важности события «Информация».

Во второй строке отобразилась картинка, для уровня важности события «Ошибка».

В третьей строке отобразилась картинка, для уровня важности события «Предупреждение».

В третьей строке отобразилась картинка, для уровня важности события «Примечание».

Метод ЗаписьЖурналаРегистрации.
Параметр ОбъектМетаданных

ОбъектМетаданных – описывает к какому объекту метаданных относится событие (Рис. 3). Не обязателен для заполнения.

Метод ЗаписьЖурналаРегистрации. Параметр Данные

Данные – описывает данные с которыми связано событие (Рис. 4).

Метод ЗаписьЖурналаРегистрации. Параметр Комментарий

Комментарий – описывает комментарий, связанный с событием (Рис. 5).

Метод ЗаписьЖурналаРегистрации. Параметр РежимТранзакции

РежимТранзакции — определяет отношение в 1С записи журнала регистрации к текущей транзакции.

Значения:

РежимТранзакцииЗаписиЖурналаРегистрации.Независимая

РежимТранзакцииЗаписиЖурналаРегистрации.Транзакционная

Быков Владимир,

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

Довольно часто начинающие 1С разработчики сталкиваются с ошибками, которых достаточно легко избежать. Ниже мы рассмотрим топ 11 ошибок и способы их исправления. Также доступна видеоверсия статьи

Содержание

Поле объекта не обнаружено

1С ошибка Поле объекта не обнаружено

Существует множество статей, которые описывают возможные причины возникновения в 1С ошибки “Поле объекта не обнаружено”. Порой это связывают с обновлением платформы, обновлением типового релиза, или с какими-то другими причинами.

Мы же будем оперировать фактами. В конце статьи прилагается внешняя обработка, в которой воспроизведена данная ошибка.

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

  • Удалили табличную часть, к которой обращаемся в коде?
  • Переименовали реквизит, а в коде не исправили?
  • Заменили значение со ссылки на неопределено?

Вуаля – платформа выдаст ошибку “Поле объекта не обнаружено”!

Как исправить? Исходя из природы ошибки – переименовать реквизит на нужное имя, отредактировать код, или использовать правильные обращения к стандартным свойствам объекта.

Например, у объекта “СообщениеПользователю” нет свойства “Таблица”, и следующий код приведет к ошибке:

Сообщение = Новый СообщениеПользователю;
Сообщение.Таблица = “Ошибка”;

Индекс находится за границами массива

1С ошибка Индекс находится за пределами массива

Что означает такое сообщение системы? Как правило, с данной ошибкой разработчик сталкивается при некорректной работе с коллекциями. Самые частые случаи появления ошибки “Индекс находится за границами массива”.

  • Использование при обходе коллекции количества элементов вместо индекса. Индексы начинаются с нуля, а количество элементов – с единицы. Поэтому следующий код гарантированно приведет к ошибке: Массив[Массив.Количество()]
  • Последствия удаления элементов из коллекции, очистки коллекции или замены коллекции на пустую
  • Ошибочное увеличение счетчика в цикле “Для”

 Как исправить? Для удаления элементов из коллекции по условию – использовать обратный цикл. Добавлять условие на соответствие счетчика цикла и индекса массива. Не увеличивать счетчик внутри кода цикла Для … Цикл … КонецЦикла

Обращение к процедуре как к функции

ОШибка

Суть этой ошибки в том, что процедура не может возвращать значение. И если мы в коде используем вызов процедуры справа от знака присваивания, это приведет к ошибке.

Данная ошибка имеет две вариации – если используется стандартная процедура из методов какого-нибудь объекта, то фраза будет звучать “Обращение к процедуре объекта как к функции”. Если же использовать процедуру, объявленную в коде, то текст ошибки будет “Обращение к процедуре как к функции”.
При этом ошибка использования процедуры объекта является ошибкой времени выполнения – т.е. на этапе сохранения и проверки конфигурации платформа эту ошибку не обнаружит.

А вот неправильное использование процедуры синтаксическая проверка (Ctrl + F7) успешно обнаруживает, и не даст сохранить конфигурацию или внешнюю обработку/отчет, пока ошибка не будет устранена.

Рассмотрим два примера:

1. Воспроизведем ошибку “Обращение к процедуре как к функции”. При этом платформа не даст сохранить изменения, т.к. не проходит синтакс-контроль.

2. Воспроизведем ошибку “Обращение к процедуре объекта как к функции”. Здесь мы неверно используем метод объекта массива “Добавить”, который является процедурой.

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

Процедура не может возвращать значение

Родственная предыдущей ошибка. Для того, чтобы код возвращал какое-то значение, следует этот код размещать в функции, а не в процедуре.

В процедуре можно написать ключевое слово “Возврат” без параметров. Это будет означать выход из процедуры.

Следующий код является ошибочным, т.к. в теле процедуры Возврат используется с параметром:

Процедура ПроцедураНеМожетВозвращатьЗначение(Команда)
Возврат "Ошибка";
КонецПроцедуры

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

Переменная не определена

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

  • Опечатка в имени переменной
  • Обращение к переменной, которая нигде в области видимости не объявлена (неявной инициализацией с присвоением значения, явным образом с использованием ключевого слова “Перем”, или передана в качестве параметра)
  • Написание на клиенте серверного кода. Например, обращение к менеджеру справочников “Справочники”, и т.п. Клиентская часть приложения “не видит ” серверные объекты языка
  • Также ошибка может появиться, если ранее код использовался в режиме толстого клиента, но после был запущен в тонком клиенте.

Как исправить?

Внимательно следить за правильностью набранного кода, своевременно объявлять переменные или передавать их в качестве параметров. Писать серверный код только в серверных модулях, а также использовать соответствующие инструкции препроцессора, например “&НаСервере”.

Значение не является значением объектного типа

Ошибка “Значение не является значением объектного типа” может возникнуть при неверном обращении к объекту языка. Объектный тип – это такие объекты языка, которые содержат в себе другие объекты – свойства, реквизиты и т.п. Эти свойства доступны через точку, например “Объект.СвойствоЭтогоОбъекта”

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

Разберем более сложный пример:

&НаСервере
Процедура ЗначениеНеЯвляетсяЗначениемОбъектногоТипаНаСервере(Справочники = Ложь)
Сообщить(Справочники.Сотрудники.ПустаяСсылка());
КонецПроцедуры

Ошибка может быть “плавающей”. Если вместо параметра по умолчанию “Справочники = Ложь” будет передан менеджер справочников, то ошибки возникать не будет. А если вызвать процедуру без параметров, то будет использоваться параметр по умолчанию с типом Булево, что и приведет к ошибке.

Чаще всего чтобы исправить ошибку, нужно в отладчике посмотреть, какой тип значения используется. Можно внести изменения в код, чтобы обеспечить корректное поведение (например, в запросе вместо наименования товара выбрать ссылку, и в коде через точку уже обращаться к свойствам ссылки, а не текстового наименования). А можно добавить проверку на нужный тип значения. Т.е. – если значение того типа, который мы ожидаем – выполняем код. Иначе – не выполняем.

Ошибка при вызове метода контекста

Ошибка при вызове метода контекста

Обнаружены ошибки в 1С Синтаксическая ошибка

В языке 1С у разных объектов (запросов, справочников, табличных документов и др.) есть предопределенные методы, предусмотренные платформой. Обращение к этим методам требует соблюдения порядка и параметров, правильного синтаксиса и соблюдения условий использования. Например, при чтении табличного документа из файла он не должен быть открыт в другой программе, при подключении к http-соединению оно должно быть доступно, и т.п.

Если эти условия не соблюдать, платформа в зависимости от версии может выдавать сообщения вида “Ошибка при вызове метода контекста”, и далее будут следовать более подробные сведения об ошибке – стек вызовов, приведших к ошибке, номер строки и позиции в строке, где произошла ошибка.

Чаще всего ошибка при вызове метода контекста встречается в следующих методах:

  1. Записать
  2. Прочитать
  3. Выполнить
  4. Создать
  5. ПроверитьВывод

Разберем эту ошибку на примере метода Выполнить объекта Запрос:

Запрос = Новый Запрос("ВЫБРАТЬ ПЕРВЫЕ 1 1 ГДЕ ИСТИНА И");
Запрос.Выполнить();

В тексте запроса допущена ошибка –  после первого условия “ГДЕ ИСТИНА” указан оператор И, но после него нет еще одного условия. В результате при попытке выполнения запроса, платформа вернет ошибку.

Для исправления ошибки зачастую достаточно внимательно использовать методы, при необходимости уточнять порядок, количество и тип параметров – это можно сделать в справке или синтакс-помощнике (встать курсором на имя метода в коде, и нажать сочетание клавиш Ctrl+F1). В случае запроса – нужно передавать синтаксически корректный текст запроса; в случае проверки вывода на печать – в системе должен быть установлен принтер; в случае подключения к почте – должны быть корректно указаны логин и пароль, и т.п.

Тип не может быть выбран в запросе в 1С 8.3 (8.2)

Ошибка Тип не может быть выбран в запросе

С такой ошибкой начинающие разработчики (да и не только начинающие 😉 ) сталкиваются чаще всего, при чтении запросом данных из таблиц значений, либо из регистров сведений. Все дело в том, что запросы поддерживают далеко не все типы значений. Так, например, нельзя запросом выбрать тип Картинка, ХранилищеЗначений, Шрифт, и многие другие типы, которые не относятся к примитивным или ссылочным типам значений.

Так, если ресурс регистра сведений имеет тип ХранилищеЗначений, выбрать его запросом будет нельзя. Также, если в таблицу значений поместить значения не подходящих типов, а после передать эту таблицу в качестве параметра-источника данных, выполнение запроса также приведет к ошибке “Тип не может быть выбран в запросе”.

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

Неверно:

//ТЗОшибочныйТип.Колонки.Добавить("Контрагент");

Верно:

//ТЗОшибочныйТип.Колонки.Добавить("Контрагент", Новый ОписаниеТипов("СправочникСсылка.Контрагенты"));

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

Использование в 1С модальных окон в данном режиме запрещено

Ошибка Использование в 1С модальных окон в данном режиме запрещено​

Платформа будет выдавать такое сообщение, если в коде используются методы, приводящие к открытию модальных окон. Модальные окна – это окна, которые при открытии блокируют весь остальной интерфейс. В 1С есть несколько модальных методов – например – “Вопрос”, “ОткрытьЗначение”, “Предупреждение”. Кроме того, в коде может использоваться модальный синтаксис открытия форм: “ОткрытьМодально()”

Если в свойствах конфигурации выбран режим использования модальности “Не использовать”, то выполнение модальных методов будет приводить к этой ошибке “Использование в 1С модальных окон в данном режиме запрещено”.

Для устранения ошибки можно пойти несколькими путями. Как водится, один – быстрый, другой – правильный 🙂

Быстрый способ – переключить режим использования модальности в положение “Использовать”.

Более правильный способ – использовать в коде немодальные вызовы методов. Например, у метода “Вопрос” есть немодальный аналог  – “ПоказатьВопрос”, у метода “Предупреждение” – “ПоказатьПредупреждение”, и т.п. Чаще всего об этих методах дополнительно указано в синтакс-помощнике и справке.

Кроме того, в последних версиях платформы появились асинхронные методы – “ВопросАсинх”, “ПредупреждениеАсинх” и др. Появление этих методов позволяет писать более простой и понятный асинхронный код, и направлено в первую очередь, на более полноценную поддержку браузерами и работу в веб-клиенте.

1С 8.3 и 8.2: Запись с такими ключевыми полями существует!

Данная ошибка появляется при некорректной записи в регистр сведений. Чаще всего с этой ошибкой сталкиваются начинающие разработчики, не до конца понимающие механизмы работы с ключевыми полями (измерениями).

Суть ошибки следующая – регистр сведений позволяет записать запись (строку таблицы) с уникальным набором ключевых полей – а для периодических регистров также и поля Период. Если следующая запись полностью повторяет значение ключевых полей, но осуществляется методом Записать с параметром Замещать = Истина, то запись в таблице регистра просто заменится на идентичную.

Однако если поместить две абсолютно одинаковые записи в набор записей, и попытаться его записать – платформа выдаст ошибку. Еще один распространенный случай, когда 1С сообщает “Запись с такими ключевыми полями существует” – это запись в периодический регистр сведений с периодичностью от “День” и выше, подчиненный регистратору.

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

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

Поле объекта недоступно для записи в 1С

Ошибка Поле объекта недоступно для записи в 1С​

Чаще всего начинающие программисты 1С сталкиваются с этой ошибкой в двух ситуациях.

Первый случай – это попытка редактирования системных полей, недоступных для записи. Например, в модуле формы сама форма будет содержаться в объекте ЭтаФорма. И попытка присвоить этому реквизиту любое значение приведет к ошибке “Поле объекта недоступно для записи”.

Второй случай – и с ним новички как раз допускают больше всего ошибок – это попытка редактирования полей ссылки, а не самого объекта. Чаще всего код выглядит примерно так:

Элемент = Справочники.Сотрудники.НайтиПоКоду("12345");
Элемент.Наименование = "Новое наименование";

 

Исполнение данного кода приведет к ошибке, т.к. поля ссылки доступны только для чтения, а метод НайтиПоКоду вернет именно ссылку. Чтобы можно было внести изменения, следует из ссылки получить сам объект – используя соответствующий метод ПолучитьОбъект().

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

Ссылка на обработку

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

Заключение

Как видите, зачастую ошибки тривиальны, и достаточно просто исправляются. Общие рекомендации – внимательно читать документацию и справку, корректно использовать методы, активно пользоваться отладчиком. Если вы новичок, и хотите освоить программирование в 1С с нуля – могу предложить приобрести мой базовый курс для начинающих. Более подробная информация – по ссылке.

Понравилась статья? Поделить с друзьями:

Интересное по теме:

  • 1с ошибка при вызове метода контекста записатьjson
  • 1с ошибка при вызове метода контекста закрыть
  • 1с ошибка при вызове метода контекста закончитьчтение
  • 1с ошибка при вызове метода контекста загрузитьвнешнююкомпоненту
  • 1с ошибка при вызове метода контекста загрузить

  • Добавить комментарий

    ;-) :| :x :twisted: :smile: :shock: :sad: :roll: :razz: :oops: :o :mrgreen: :lol: :idea: :grin: :evil: :cry: :cool: :arrow: :???: :?: :!: