Как можно сделать, скажем, чтобы выполнялся только один конкретный макрос соответствующей ячейки?

VBA

"""Для чего нужна переменная bInsert?
Может так подойдет?
Private Sub Worksheet_Calculate()
Application.EnableEvents = False
If [g28] = 1 Then Макрос1
If [g28] <> 1 Then Макрос2
If [g29] = 1 Then Макрос3
If [g29] <> 1 Then Макрос4
Application.EnableEvents = True
End Sub

"С ячейкой G28 все работает" не работает.
При первой проверке bInsert, значение которой Empty, т.е. не равно False запускается Макрос1 и bInsert присваивается True. Поэтому далее ни один макрос сработать не может."""

Спасибо. Все работает, но теперь начинает пересчитывать ВСЕ макросы ( а у меня их там не 4, а куда больше ), а так же при изменении любой ячейки, не только тех, что указаны в коде. из-за этого начинает тупить.
Как можно сделать, скажем, чтобы выполнялся только один конкретный макрос соответствующей ячейки? Спасибо.
Ответы:
Я не знаю вашей задачи. Какое событие вызывает пересчет листа.
Если изменение значений в G28 и G29, то возможно такой код подойдет.


11 лет назад

RPI.su - самая большая русскоязычная база вопросов и ответов. Наш проект был реализован как продолжение популярного сервиса otvety.google.ru, который был закрыт и удален 30 апреля 2015 года. Мы решили воскресить полезный сервис Ответы Гугл, чтобы любой человек смог публично узнать ответ на свой вопрос у интернет сообщества.

Все вопросы, добавленные на сайт ответов Google, мы скопировали и сохранили здесь. Имена старых пользователей также отображены в том виде, в котором они существовали ранее. Только нужно заново пройти регистрацию, чтобы иметь возможность задавать вопросы, или отвечать другим.

Чтобы связаться с нами по любому вопросу О САЙТЕ (реклама, сотрудничество, отзыв о сервисе), пишите на почту [email protected]. Только все общие вопросы размещайте на сайте, на них ответ по почте не предоставляется.