Перейти к основному контенту
Поддержка
Войдите с помощью учетной записи Майкрософт
Войдите или создайте учетную запись.
Здравствуйте,
Выберите другую учетную запись.
У вас несколько учетных записей
Выберите учетную запись, с помощью которой нужно войти.

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

Примечание: Макрокоманда "ПриОшибке" недоступна в веб-приложениях Access.

Настройка

Макрокоманда ПриОшибке имеет следующие аргументы:

Аргумент макрокоманды

Описание

Перейти

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

Параметр

Описание

Далее

Access записывает подробные сведения об ошибке в объекте ОшибкаМакроса, но не останавливает макрос. Выполнение продолжается со следующей макрокоманды.

Имя макроса

Access останавливает выполнение текущего макроса и запускает макрос, указанный в аргументе Имя макроса.

Сбой

Access останавливает выполнение текущего макроса и отображает сообщение об ошибке.

Имя макроса

Если аргумент Перейти имеет значение Имя макроса, введите имя макроса, который будет использоваться для обработки ошибок. Введенное имя должно соответствовать имени вложенного макроса для текущего макроса; нельзя указать имя другого объекта. В следующем примере макрос "ОбработчикОшибок" содержится в том же объекте макроса, что и макрокоманда ПриОшибке.

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

Замечания

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

  • Если для аргумента Go to задано значение Fail, Access будет вести себя так же, как и при отсутствии действия OnError в макросе. То есть при обнаружении ошибки Access останавливает макрос и отображает стандартное сообщение об ошибке. Для параметра Fail main используется отключение обработки ошибок, установленных ранее в макросе.

Пример

Следующий макрос демонстрирует использование макрокоманды ПриОшибке. В данном примере макрокоманда ПриОшибке указывает, что при возникновении ошибки будет выполнен пользовательский вложенный макрос "ОбработчикОшибок". Если в любой из последующих макрокоманд произойдет ошибка, Access перейдет к вложенному макросу "ОбработчикОшибок". Макрос "ОбработчикОшибок" отображает окно сообщения с данными об ошибке из объекта ОшибкаМакроса.

Имя вложенного макроса

Макрокоманда

Аргументы

ПриОшибке

Перейти: Имя макроса

Имя макроса: ОбработчикОшибок

[Макрокоманда 2]

...

[Макрокоманда n]

ОбработчикОшибок

Окно сообщения

Сообщение: ="Ошибка" & [MacroError].[Номер] & "в макрокоманде" & [MacroError].[ИмяМакрокоманды].

Сигнал: Да

Тип: Отсутствует

Заголовок: Произошла ошибка

Ниже показан снимок экрана с конструктором макросов Access (в Access 2010 или более поздней версии), в котором настроен макрос из предыдущего примера. В этом случае выражение в макрокоманде ЗадатьЛокПеременную вызывает ошибку из-за попытки деления на нуль. Access переходит к вложенному макросу с именем "ОбработчикОшибок" и выводит окно сообщения со сведениями об ошибке.

Рабочая область конструирования макросов Access с макрокомандой "ПриОшибке".

Нужна дополнительная помощь?

Нужны дополнительные параметры?

Изучите преимущества подписки, просмотрите учебные курсы, узнайте, как защитить свое устройство и т. д.

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

Были ли сведения полезными?

Насколько вы удовлетворены качеством перевода?
Что повлияло на вашу оценку?
После нажатия кнопки "Отправить" ваш отзыв будет использован для улучшения продуктов и служб Майкрософт. Эти данные будут доступны для сбора ИТ-администратору. Заявление о конфиденциальности.

Спасибо за ваш отзыв!

×