Обратно к инструкциям
Иногда возникает ситуация, когда журнал звонков перестает загружать новые записи истории звонков из АТС, и в журнале регистрации 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. Сбросьте все привязки лицензии от хоста по инструкции.
Обратно к инструкциям
IF_THEN
10.11.09
✎
13:34
Добрый день, ребята кто подскажет что я делаю не так. Из 8 ки по ОЛЕ соединяюсь с 7.7. в 7 ой базе создаю объект. Далее хочу в журнал 7ой базы записать событие создания объякта. Пишу База77.ЗаписьЖурналаРегистрации(«Создан новый объект»,»Refs»,»RefNew»,справочник77,2); справочник77 = База77.CreateObject(«Справочник.Номенклатура»);
ДенисЧ
10.11.09
✎
13:35
не взлетит.
IF_THEN
10.11.09
✎
13:47
ща турбо надув дам и взлетит!
dk
10.11.09
✎
13:52
взлетит, если пнуть с подвывертом )
dk
10.11.09
✎
13:58
EvalExpr и ExecuteBatch еще никто не отменял )))
IF_THEN
10.11.09
✎
14:17
Щас протестю
IF_THEN
10.11.09
✎
15:10
База77.EvalExpr(«НайденныйОбъект=СоздатьОбъект(«»Справочник.Договоры»»);»)
{(1)}: Ошибка при вызове метода контекста (EvalExpr): Произошла исключительная ситуация (1С:Предприятие): 1 НайденныйОбъект<<?>>=СоздатьОбъект(«Справочник.Договоры»);
Переменная не определена (НайденныйОбъект)
не подскажете почему ругается, синтаксис правильный же
Михей
10.11.09
✎
15:12
(6) CreateObject?
IF_THEN
10.11.09
✎
15:13
(7) смотри (0) надо взять ссылку на элемент 7 ки и подставить в процедуру регистрации события
dk
10.11.09
✎
15:13
(6) неправильно идею понял
IF_THEN
10.11.09
✎
15:14
(9) ммм, да? не подскажешь твою идею?
dk
10.11.09
✎
15:14
(8) ЗначениеИзСтрокиВнутр(ЗначениеВстрокуВнутр())
+ двойные кавычки учесть
Шахид
10.11.09
✎
15:15
(10) а может напрямую в mlg писать или режим разделенный?
IF_THEN
10.11.09
✎
15:16
(11) ну да, тема так можно передать объект. Но я вот выполнил запись в журнал без передачи объекта,и чет в журнал нече не добавилось.
IF_THEN
10.11.09
✎
15:16
(12) не напрямую не нужно писать
Шахид
10.11.09
✎
15:17
(14) жаль. такая идея пропадает
dk
10.11.09
✎
15:22
База77.ExecuteBatch(«ЗаписьЖурналаРегистрации(«»Создан новый объект»»,»»Refs»»,»»RefNew»»,ЗначениеИзСтрокиВнутр(«+База77.ЗначениеВстрокуВнутр(справочник77.ТекущийЭлемент())+»),2);»)
dk
10.11.09
✎
15:23
База77.ExecuteBatch(«ЗаписьЖурналаРегистрации(«»Создан новый объект»»,»»Refs»»,»»RefNew»»,ЗначениеИзСтрокиВнутр(«»»+СтрЗаменить(База77.ЗначениеВстрокуВнутр(справочник77.ТекущийЭлемент(),»»»»,»»»»»»))+»»»),2);»);
или так ))
Шахид
10.11.09
✎
15:24
ТекущийЭлемент() по оле вроде не летает?
dk
10.11.09
✎
15:29
Кто сказал?
IF_THEN
10.11.09
✎
15:29
(18) летает
dk
10.11.09
✎
15:29
напрямую нет, но обернутый летает
IF_THEN
10.11.09
✎
15:31
интересно а почему без объекта не записывается событие. в отладке показывает выполнение метода ExecuteBatch истина, а в списке журнала нече не появляется. Все фильтры выставлены по все да и период нормальный..
dk
10.11.09
✎
15:37
(15) эта идея давно реализована, у меня в том числе )
IF_THEN
10.11.09
✎
15:38
в общем просто журнал регистраций настроен так что регистрируе пока только вход и выход))) p.s. на демке тестю
dk спасибо за инфо
Процедура ПрименитьПараметрыУчета(ПараметрыУчета, ИзмененыПараметрыСубконто = Ложь, Отказ = Ложь) Экспорт
ПризнакиУчета = ПолучитьСтруктуруПризнаковУчетаСубконто();
ДействияИзмененияСубконто = ПолучитьДействияИзмененияСубконто(ПараметрыУчета); // Иерархическая коллекция: на первом уровне действия с субконто на каждом из счетов, на втором — действия с призаками учета.
// Сгруппируем изменения по счетам, так как записывать будем именно счет
СчетаКИзменению = ОбщегоНазначения.ВыгрузитьКолонку(ДействияИзмененияСубконто, «Счет», Истина);
ДействияИзмененияСубконто.Индексы.Добавить(«Счет»);
Отбор = Новый Структура(«Счет»);
НачатьТранзакцию();
Для Каждого Счет Из СчетаКИзменению Цикл
Отбор.Счет = Счет;
ДействияДляСчета = ДействияИзмененияСубконто.НайтиСтроки(Отбор);
Объект = Счет.ПолучитьОбъект();
ПротоколИзменений = Новый Массив;
Для Каждого Действие Из ДействияДляСчета Цикл
// Действие: -1 удалить; 0 — не менять; 1 — установить
// Действия с видом субконто
Если Действие.Действие = 1 Тогда
// Добавить субконто
Если Счет = ПланыСчетов.Хозрасчетный.РасчетыСПерсоналомПоОплатеТруда Тогда
ВидыСубконтоСтрока = Объект.ВидыСубконто.Вставить(0);
Иначе
ВидыСубконтоСтрока = Объект.ВидыСубконто.Добавить();
КонецЕсли;
ВидыСубконтоСтрока.ВидСубконто = Действие.Субконто;
ДобавитьВПротоколИзменениеСубконто(ПротоколИзменений, ВидыСубконтоСтрока.ВидСубконто, Действие.Действие);
Иначе
ВидыСубконтоСтрока = Объект.ВидыСубконто.Найти(Действие.Субконто, «ВидСубконто»);
Если ВидыСубконтоСтрока = Неопределено Тогда
Продолжить;
КонецЕсли;
КонецЕсли;
Если Действие.Действие = -1 Тогда
ДобавитьВПротоколИзменениеСубконто(ПротоколИзменений, ВидыСубконтоСтрока.ВидСубконто, Действие.Действие);
Объект.ВидыСубконто.Удалить(ВидыСубконтоСтрока);
Продолжить;
КонецЕсли;
// Действия с признаками учета
Для Каждого ПризнакУчета Из ПризнакиУчета Цикл
ДействиеСПризнаком = Действие[ПризнакУчета.Ключ];
Если ДействиеСПризнаком = 1 Тогда
ЗначениеПризнака = Истина;
ИначеЕсли ДействиеСПризнаком = -1 Тогда
ЗначениеПризнака = Ложь;
Иначе
Продолжить;
КонецЕсли;
Если ВидыСубконтоСтрока[ПризнакУчета.Ключ] = ЗначениеПризнака Тогда
Продолжить;
КонецЕсли;
ВидыСубконтоСтрока[ПризнакУчета.Ключ] = ЗначениеПризнака;
ДобавитьВПротоколИзменениеПризнакаУчета(
ПротоколИзменений,
ВидыСубконтоСтрока.ВидСубконто,
ПризнакУчета.Значение,
ДействиеСПризнаком);
КонецЦикла; // По признакам учета
КонецЦикла; // По ДействияДляСчета
Если Не Объект.Модифицированность() Тогда
Продолжить;
КонецЕсли;
ПротоколИзмененийСтрокой = СтрСоединить(ПротоколИзменений, Символы.ПС);
Попытка
Объект.Записать();//ВОТ ТУТ ВАЛИТСЯ
Исключение
ОписаниеОшибки = ИнформацияОбОшибке();
ОтменитьТранзакцию();
Отказ = Истина;
ШаблонТекста = НСтр(«ru = ‘Ошибка при записи счета [КодСчета]:
|[ОписаниеОшибки]
|Ошибка произошла при попытке выполнить следующие изменения:
|[ПротоколИзменений]'»);
ПараметрыТекста = Новый Структура;
ПараметрыТекста.Вставить(«КодСчета», Объект.Код);
ПараметрыТекста.Вставить(«ПротоколИзменений», ПротоколИзмененийСтрокой);
// В журнал регистрации выведем подробную информацию
ПараметрыТекста.Вставить(«ОписаниеОшибки», ПодробноеПредставлениеОшибки(ОписаниеОшибки));
Текст = СтроковыеФункцииКлиентСервер.ВставитьПараметрыВСтроку(ШаблонТекста, ПараметрыТекста);
ЗаписьЖурналаРегистрации(
СобытиеЖурналаРегистрацииПараметрыУчета(),
УровеньЖурналаРегистрации.Ошибка,
Счет.Метаданные(),
Счет, // Данные
Текст);
// Пользователю выведем краткое сообщение
ШаблонТекста = НСтр(«ru = ‘Ошибка при записи счета [КодСчета]
|Подробности см. в Журнале регистрации.'»);
Текст = СтроковыеФункцииКлиентСервер.ВставитьПараметрыВСтроку(ШаблонТекста, ПараметрыТекста);
ОбщегоНазначенияКлиентСервер.СообщитьПользователю(Текст);
Возврат;
КонецПопытки;
// Запишем в журнал регистрации подробную информацию об изменениях
ЗаписьЖурналаРегистрации(
СобытиеЖурналаРегистрацииПараметрыУчета(),
УровеньЖурналаРегистрации.Информация,
Счет.Метаданные(),
Счет,
ПротоколИзмененийСтрокой,
РежимТранзакцииЗаписиЖурналаРегистрации.Транзакционная);
КонецЦикла; // По СчетаКИзменению
БухгалтерскийУчетПереопределяемый.УстановитьПараметрыУчетаРасчетовПоЗарплате(?(ПараметрыУчета.ВестиУчетПоРаботникам = 1, Ложь, Истина));
БухгалтерскийУчетПереопределяемый.УстановитьУчетЗарплатыИКадровВоВнешнейПрограмме(?(ПараметрыУчета.УчетЗарплатыИКадровВоВнешнейПрограмме = 1, Истина, Ложь));
БухгалтерскийУчетПереопределяемый.УстановитьНастройкиКадровогоУчета(ПараметрыУчета.КадровыйУчет, ?(ПараметрыУчета.УчетЗарплатыИКадровВоВнешнейПрограмме = 0, Истина, Ложь));
ЗафиксироватьТранзакцию();
ОбновитьПовторноИспользуемыеЗначения();
КонецПроцедуры
Содержание:
- Для чего нужен метод ЗаписьЖурналаРегистрации?
- Параметры метода ЗаписьЖурналаРегистрации в системе конфигурации 1С
Для чего нужен метод ЗаписьЖурналаРегистрации?
Не все события, которые происходят в пользовательском режиме 1С автоматически фиксируется платформой. Поэтому бывает потребность сделать в 1С запись журнала регистрации. Для таких случаев можно использовать метод ЗаписьЖурналаРегистрации.
Глобальный контекст
Метод ЗаписьЖурналаРегистрации служит для фиксации события в журнал регистрации. Доступен на серверной части, в толстом клиенте и при внешнем соединении 1С. Обязательно должен быть заполнен параметр <ИмяСобытия>.
Параметры метода ЗаписьЖурналаРегистрации в системе конфигурации 1С
Метод ЗаписьЖурналаРегистрации. Параметр «ИмяСобытия»
ИмяСобытия – описывает содержание события (Рис.1). Обязателен для заполнения. Текст имени события не должен содержать символов «_$» и «$_».
Установим для первого параметра «ИмяСобытия» значение равное «Загрузка. Начало». В режиме конфигуратора в 1С запишем код (Рис. 1). В пользовательском режиме 1С выполним метод ЗаписьЖурналаРегистрации.
Журнал регистрации
Откроем журнал регистрации и посмотрим результат. В окне «Журнал регистрации» была сделана запись. В поле «Событие» было записано значение первого параметра метода ЗаписьЖурналаРегистрации.
Метод ЗаписьЖурналаРегистрации. Параметр «Уровень»
Уровень – описывает уровень важности события (Рис. 2). Не обязателен для заполнения.
Значения:
УровеньЖурналаРегистрации.Информация
УровеньЖурналаРегистрации.Ошибка
УровеньЖурналаРегистрации.Предупреждение
УровеньЖурналаРегистрации.Примечание Установим для параметра «Уровень» значения, приведенные на рисунке 2. В режиме конфигуратора в 1С запишем код (Рис. 1). В пользовательском режиме 1С выполним метод ЗаписьЖурналаРегистрации
Загрузка. Начало
Откроем журнал регистрации и посмотрим результат. В окне «Журнал регистрации» были сделаны записи. В каждой строке в первом поле в виде картинки отобразилось значение параметра «Уровень» метода ЗаписьЖурналаРегистрации.
В первой строке отобразилась картинка, для уровня важности события «Информация».
Во второй строке отобразилась картинка, для уровня важности события «Ошибка».
В третьей строке отобразилась картинка, для уровня важности события «Предупреждение».
В третьей строке отобразилась картинка, для уровня важности события «Примечание».
Метод ЗаписьЖурналаРегистрации.
Параметр ОбъектМетаданных
ОбъектМетаданных – описывает к какому объекту метаданных относится событие (Рис. 3). Не обязателен для заполнения.
Метод ЗаписьЖурналаРегистрации. Параметр Данные
Данные – описывает данные с которыми связано событие (Рис. 4).
Метод ЗаписьЖурналаРегистрации. Параметр Комментарий
Комментарий – описывает комментарий, связанный с событием (Рис. 5).
Метод ЗаписьЖурналаРегистрации. Параметр РежимТранзакции
РежимТранзакции — определяет отношение в 1С записи журнала регистрации к текущей транзакции.
Значения:
РежимТранзакцииЗаписиЖурналаРегистрации.Независимая
РежимТранзакцииЗаписиЖурналаРегистрации.Транзакционная
Быков Владимир,
Специалист компании ООО «Кодерлайн»
Довольно часто начинающие 1С разработчики сталкиваются с ошибками, которых достаточно легко избежать. Ниже мы рассмотрим топ 11 ошибок и способы их исправления. Также доступна видеоверсия статьи
Содержание
Поле объекта не обнаружено
Существует множество статей, которые описывают возможные причины возникновения в 1С ошибки “Поле объекта не обнаружено”. Порой это связывают с обновлением платформы, обновлением типового релиза, или с какими-то другими причинами.
Мы же будем оперировать фактами. В конце статьи прилагается внешняя обработка, в которой воспроизведена данная ошибка.
Такое сообщение платформа выдает, когда пытается обратиться к свойству объекта языка, которого у данного объекта нет. Не важно, что это за объект – документ, справочник, таблица значений , или сообщение пользователю.
- Удалили табличную часть, к которой обращаемся в коде?
- Переименовали реквизит, а в коде не исправили?
- Заменили значение со ссылки на неопределено?
Вуаля – платформа выдаст ошибку “Поле объекта не обнаружено”!
Как исправить? Исходя из природы ошибки – переименовать реквизит на нужное имя, отредактировать код, или использовать правильные обращения к стандартным свойствам объекта.
Например, у объекта “СообщениеПользователю” нет свойства “Таблица”, и следующий код приведет к ошибке:
Сообщение = Новый СообщениеПользователю;
Сообщение.Таблица = “Ошибка”;
Индекс находится за границами массива
Что означает такое сообщение системы? Как правило, с данной ошибкой разработчик сталкивается при некорректной работе с коллекциями. Самые частые случаи появления ошибки “Индекс находится за границами массива”.
- Использование при обходе коллекции количества элементов вместо индекса. Индексы начинаются с нуля, а количество элементов – с единицы. Поэтому следующий код гарантированно приведет к ошибке: Массив[Массив.Количество()]
- Последствия удаления элементов из коллекции, очистки коллекции или замены коллекции на пустую
- Ошибочное увеличение счетчика в цикле “Для”
Как исправить? Для удаления элементов из коллекции по условию – использовать обратный цикл. Добавлять условие на соответствие счетчика цикла и индекса массива. Не увеличивать счетчик внутри кода цикла Для … Цикл … КонецЦикла
Обращение к процедуре как к функции
Суть этой ошибки в том, что процедура не может возвращать значение. И если мы в коде используем вызов процедуры справа от знака присваивания, это приведет к ошибке.
Данная ошибка имеет две вариации – если используется стандартная процедура из методов какого-нибудь объекта, то фраза будет звучать “Обращение к процедуре объекта как к функции”. Если же использовать процедуру, объявленную в коде, то текст ошибки будет “Обращение к процедуре как к функции”.
При этом ошибка использования процедуры объекта является ошибкой времени выполнения – т.е. на этапе сохранения и проверки конфигурации платформа эту ошибку не обнаружит.
А вот неправильное использование процедуры синтаксическая проверка (Ctrl + F7) успешно обнаруживает, и не даст сохранить конфигурацию или внешнюю обработку/отчет, пока ошибка не будет устранена.
Рассмотрим два примера:
1. Воспроизведем ошибку “Обращение к процедуре как к функции”. При этом платформа не даст сохранить изменения, т.к. не проходит синтакс-контроль.
2. Воспроизведем ошибку “Обращение к процедуре объекта как к функции”. Здесь мы неверно используем метод объекта массива “Добавить”, который является процедурой.
Как исправить? Ошибка тривиальная, и исправление тоже. Чаще всего, достаточно внимательно прочитать описание методов объекта во встроенной справке или синтакс-помощнике. Если метод является процедурой, то значений он возвращать не может. Следовательно, нужно модифицировать код так, чтобы такого ошибочного вызова не было.
Если же используется процедура, объявленная в коде, возможно, есть необходимость изменить ее на функцию, либо также скорректировать код, который эту процедуру использует.
Процедура не может возвращать значение
Родственная предыдущей ошибка. Для того, чтобы код возвращал какое-то значение, следует этот код размещать в функции, а не в процедуре.
В процедуре можно написать ключевое слово “Возврат” без параметров. Это будет означать выход из процедуры.
Следующий код является ошибочным, т.к. в теле процедуры Возврат используется с параметром:
Процедура ПроцедураНеМожетВозвращатьЗначение(Команда) Возврат "Ошибка"; КонецПроцедуры
Как исправить? Платформа сама подсказывает, в каком месте кода ошибка. Нужно изменить текст модуля – либо удалить параметр у ключевого слова Возврат, либо убрать его вовсе, либо изменить процедуру на функцию – зависит от того, какая логика у вашей процедуры, и как вы предполагаете ее использовать.
Переменная не определена
Такой текст ошибки платформа 1С выдает на этапе синтаксического контроля, при сохранении конфигурации, внешнего отчета или обработки.
Причин у этой ошибки может быть несколько.
- Опечатка в имени переменной
- Обращение к переменной, которая нигде в области видимости не объявлена (неявной инициализацией с присвоением значения, явным образом с использованием ключевого слова “Перем”, или передана в качестве параметра)
- Написание на клиенте серверного кода. Например, обращение к менеджеру справочников “Справочники”, и т.п. Клиентская часть приложения “не видит ” серверные объекты языка
- Также ошибка может появиться, если ранее код использовался в режиме толстого клиента, но после был запущен в тонком клиенте.
Как исправить?
Внимательно следить за правильностью набранного кода, своевременно объявлять переменные или передавать их в качестве параметров. Писать серверный код только в серверных модулях, а также использовать соответствующие инструкции препроцессора, например “&НаСервере”.
Значение не является значением объектного типа
Ошибка “Значение не является значением объектного типа” может возникнуть при неверном обращении к объекту языка. Объектный тип – это такие объекты языка, которые содержат в себе другие объекты – свойства, реквизиты и т.п. Эти свойства доступны через точку, например “Объект.СвойствоЭтогоОбъекта”
Но если через точку попытаться использовать какое-то значение, которое внутри себя свойств не имеет – например, любое значение примитивного типа – это и приведет к ошибке.
Разберем более сложный пример:
&НаСервере Процедура ЗначениеНеЯвляетсяЗначениемОбъектногоТипаНаСервере(Справочники = Ложь) Сообщить(Справочники.Сотрудники.ПустаяСсылка()); КонецПроцедуры
Ошибка может быть “плавающей”. Если вместо параметра по умолчанию “Справочники = Ложь” будет передан менеджер справочников, то ошибки возникать не будет. А если вызвать процедуру без параметров, то будет использоваться параметр по умолчанию с типом Булево, что и приведет к ошибке.
Чаще всего чтобы исправить ошибку, нужно в отладчике посмотреть, какой тип значения используется. Можно внести изменения в код, чтобы обеспечить корректное поведение (например, в запросе вместо наименования товара выбрать ссылку, и в коде через точку уже обращаться к свойствам ссылки, а не текстового наименования). А можно добавить проверку на нужный тип значения. Т.е. – если значение того типа, который мы ожидаем – выполняем код. Иначе – не выполняем.
Ошибка при вызове метода контекста
В языке 1С у разных объектов (запросов, справочников, табличных документов и др.) есть предопределенные методы, предусмотренные платформой. Обращение к этим методам требует соблюдения порядка и параметров, правильного синтаксиса и соблюдения условий использования. Например, при чтении табличного документа из файла он не должен быть открыт в другой программе, при подключении к http-соединению оно должно быть доступно, и т.п.
Если эти условия не соблюдать, платформа в зависимости от версии может выдавать сообщения вида “Ошибка при вызове метода контекста”, и далее будут следовать более подробные сведения об ошибке – стек вызовов, приведших к ошибке, номер строки и позиции в строке, где произошла ошибка.
Чаще всего ошибка при вызове метода контекста встречается в следующих методах:
- Записать
- Прочитать
- Выполнить
- Создать
- ПроверитьВывод
Разберем эту ошибку на примере метода Выполнить объекта Запрос:
Запрос = Новый Запрос("ВЫБРАТЬ ПЕРВЫЕ 1 1 ГДЕ ИСТИНА И"); Запрос.Выполнить();
В тексте запроса допущена ошибка – после первого условия “ГДЕ ИСТИНА” указан оператор И, но после него нет еще одного условия. В результате при попытке выполнения запроса, платформа вернет ошибку.
Для исправления ошибки зачастую достаточно внимательно использовать методы, при необходимости уточнять порядок, количество и тип параметров – это можно сделать в справке или синтакс-помощнике (встать курсором на имя метода в коде, и нажать сочетание клавиш Ctrl+F1). В случае запроса – нужно передавать синтаксически корректный текст запроса; в случае проверки вывода на печать – в системе должен быть установлен принтер; в случае подключения к почте – должны быть корректно указаны логин и пароль, и т.п.
Тип не может быть выбран в запросе в 1С 8.3 (8.2)
С такой ошибкой начинающие разработчики (да и не только начинающие 😉 ) сталкиваются чаще всего, при чтении запросом данных из таблиц значений, либо из регистров сведений. Все дело в том, что запросы поддерживают далеко не все типы значений. Так, например, нельзя запросом выбрать тип Картинка, ХранилищеЗначений, Шрифт, и многие другие типы, которые не относятся к примитивным или ссылочным типам значений.
Так, если ресурс регистра сведений имеет тип ХранилищеЗначений, выбрать его запросом будет нельзя. Также, если в таблицу значений поместить значения не подходящих типов, а после передать эту таблицу в качестве параметра-источника данных, выполнение запроса также приведет к ошибке “Тип не может быть выбран в запросе”.
Еще одна ситуация, когда запрос будет выдавать ошибку – если таблица значений, которая передается в качестве параметра, имеет не типизированные колонки.
Неверно:
//ТЗОшибочныйТип.Колонки.Добавить("Контрагент");
Верно:
//ТЗОшибочныйТип.Колонки.Добавить("Контрагент", Новый ОписаниеТипов("СправочникСсылка.Контрагенты"));
Для исправления ошибки нужно правильным образом инициализировать колонки таблицы значений, а также не обращаться в запросе к полям, типы которых запросами не поддерживаются.
Использование в 1С модальных окон в данном режиме запрещено
Платформа будет выдавать такое сообщение, если в коде используются методы, приводящие к открытию модальных окон. Модальные окна – это окна, которые при открытии блокируют весь остальной интерфейс. В 1С есть несколько модальных методов – например – “Вопрос”, “ОткрытьЗначение”, “Предупреждение”. Кроме того, в коде может использоваться модальный синтаксис открытия форм: “ОткрытьМодально()”
Если в свойствах конфигурации выбран режим использования модальности “Не использовать”, то выполнение модальных методов будет приводить к этой ошибке “Использование в 1С модальных окон в данном режиме запрещено”.
Для устранения ошибки можно пойти несколькими путями. Как водится, один – быстрый, другой – правильный 🙂
Быстрый способ – переключить режим использования модальности в положение “Использовать”.
Более правильный способ – использовать в коде немодальные вызовы методов. Например, у метода “Вопрос” есть немодальный аналог – “ПоказатьВопрос”, у метода “Предупреждение” – “ПоказатьПредупреждение”, и т.п. Чаще всего об этих методах дополнительно указано в синтакс-помощнике и справке.
Кроме того, в последних версиях платформы появились асинхронные методы – “ВопросАсинх”, “ПредупреждениеАсинх” и др. Появление этих методов позволяет писать более простой и понятный асинхронный код, и направлено в первую очередь, на более полноценную поддержку браузерами и работу в веб-клиенте.
1С 8.3 и 8.2: Запись с такими ключевыми полями существует!
Данная ошибка появляется при некорректной записи в регистр сведений. Чаще всего с этой ошибкой сталкиваются начинающие разработчики, не до конца понимающие механизмы работы с ключевыми полями (измерениями).
Суть ошибки следующая – регистр сведений позволяет записать запись (строку таблицы) с уникальным набором ключевых полей – а для периодических регистров также и поля Период. Если следующая запись полностью повторяет значение ключевых полей, но осуществляется методом Записать с параметром Замещать = Истина, то запись в таблице регистра просто заменится на идентичную.
Однако если поместить две абсолютно одинаковые записи в набор записей, и попытаться его записать – платформа выдаст ошибку. Еще один распространенный случай, когда 1С сообщает “Запись с такими ключевыми полями существует” – это запись в периодический регистр сведений с периодичностью от “День” и выше, подчиненный регистратору.
В типовых конфигурациях часто эту ошибку можно воспроизвести, если в пользовательском режиме создать два документа “Установка цен номенклатуры” с одной и той же номенклатурой и за один и тот же день. Попытка провести второй документ приведет к ошибке.
В случае, когда ошибка возникает не в результате действий пользователя, а при выполнении кода, чтобы устранить ее, чаще всего необходимо проанализировать алгоритм записи в регистр. Если запись осуществляется одним набором данных, его предварительно нужно свернуть до уникальных записей. Например, выгрузить в таблицу значений, свернуть, и загрузить в набор записей.
Поле объекта недоступно для записи в 1С
Чаще всего начинающие программисты 1С сталкиваются с этой ошибкой в двух ситуациях.
Первый случай – это попытка редактирования системных полей, недоступных для записи. Например, в модуле формы сама форма будет содержаться в объекте ЭтаФорма. И попытка присвоить этому реквизиту любое значение приведет к ошибке “Поле объекта недоступно для записи”.
Второй случай – и с ним новички как раз допускают больше всего ошибок – это попытка редактирования полей ссылки, а не самого объекта. Чаще всего код выглядит примерно так:
Элемент = Справочники.Сотрудники.НайтиПоКоду("12345"); Элемент.Наименование = "Новое наименование";
Исполнение данного кода приведет к ошибке, т.к. поля ссылки доступны только для чтения, а метод НайтиПоКоду вернет именно ссылку. Чтобы можно было внести изменения, следует из ссылки получить сам объект – используя соответствующий метод ПолучитьОбъект().
Для исправления ошибки зачастую достаточно получить объект из ссылки. В случае же попытки редактирования свойств, доступных только на чтение самый правильный подход – анализировать имеющуюся документацию по этим свойствам, и не пытаться присваивать им значения, если платформа этого не предусматривает.
Ссылка на обработку
По ссылке вы можете скачать внешнюю обработку, в которой воспроизводится большая часть ошибок, описанных в статье. Для воспроизведения части ошибок нужно будет убрать комментарии в коде.
Заключение
Как видите, зачастую ошибки тривиальны, и достаточно просто исправляются. Общие рекомендации – внимательно читать документацию и справку, корректно использовать методы, активно пользоваться отладчиком. Если вы новичок, и хотите освоить программирование в 1С с нуля – могу предложить приобрести мой базовый курс для начинающих. Более подробная информация – по ссылке.