С Новым годом! Форум программистов, компьютерный форум, киберфорум
VBA
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.83/48: Рейтинг темы: голосов - 48, средняя оценка - 4.83
0 / 0 / 0
Регистрация: 04.03.2016
Сообщений: 3

Запуск макроса после изменения ячейки

04.03.2016, 19:34. Показов 9709. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Товарищи, подсобите, пожалуйста!
Имеется ячейка с выпадающим списком. Задача - сделать так, чтобы при выборе нового значения из списка, (т.е. изменении значения ячейки) перезапускался макрос расчетов.

Такие подпрограммы не работают. Не знаю в чем дело, но макрос НЕ перезапускается.
Visual Basic
1
2
3
4
5
6
7
8
9
 Private Sub Worksheet_Change(ByVal Target As Range)
    Dim Test As Range
    Set Test = Range("A1")
    Static Oldvalue As Variant
    If Test <> Oldvalue Then
        Call MySub
        Oldvalue = Test
    End If
End Sub
Такая подпрограмма:
Visual Basic
1
2
3
Private Sub Worksheet_Change(ByVal Target As Range)
 Call MySub
End Sub
Вылетает с бесконечным циклом, потому что при изменении значения в любой ячейке (что уже плохо) вызывается макрос, который вызывает изменения ячеек, что снова вызывает макрос...ну и т.д.

Запуск макроса при изменении ячейки
Запуск/продолжение выполнения макроса по изменению ячейки
Как привязать запуск макроса к изменению ячейки?
Процедура при изменении ячейки
Срабатывание макроса при изменении в ячейке
Запуск макроса при изменении ячейки

Эти темы можно не советовать, в них ничего полезного не оказалось.
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
04.03.2016, 19:34
Ответы с готовыми решениями:

Запуск SUB после изменения ячейки в VBA Excel
Здравствуйте, Как сделать так, чтобы при изменении ячейки, скажем, A1, выполнилась определенная процедура? Можно сделать событие...

Запуск макроса по изменению ячейки
Здравствуйте! Нашел много тем по данному вопросу, но всеравно не получается сделать даже на простом примере данную функцию. код...

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

7
 Аватар для Святой НякаЛайк
655 / 247 / 89
Регистрация: 28.10.2015
Сообщений: 526
04.03.2016, 22:00
Пишите код не в событиях изменения листа и ячеек, а в событии списка!
0
3946 / 2339 / 790
Регистрация: 02.11.2012
Сообщений: 6,214
05.03.2016, 13:53
Лучший ответ Сообщение было отмечено Agrael как решение

Решение

вариант отключить отслеживание события на время работы макроса.
Visual Basic
1
2
3
4
5
Private Sub Worksheet_Change(ByVal Target As Range)
Application.EnableEvents = False 'отключаем отслеживание событий
 Call MySub
Application.EnableEvents = True 'включаем отслеживание событий
End Sub
2
0 / 0 / 0
Регистрация: 04.03.2016
Сообщений: 3
05.03.2016, 14:01  [ТС]
А можно поподробнее?

Добавлено через 58 секунд
А как запустится макрос, если мы отключили отслеживание событий ДО его запуска?
0
3946 / 2339 / 790
Регистрация: 02.11.2012
Сообщений: 6,214
05.03.2016, 14:04
Цитата Сообщение от Agrael Посмотреть сообщение
А можно поподробнее?
код в сообщении и есть по подробней.
0
0 / 0 / 0
Регистрация: 04.03.2016
Сообщений: 3
05.03.2016, 15:37  [ТС]
Это я понял, спасибо, он заработал. Я механизм не понял. Мы отключили отслеживание изменений, вызвали подпрограмму а потом включили. Но как триггерится вызов подпрограммы?
0
1847 / 1162 / 354
Регистрация: 11.07.2014
Сообщений: 4,107
05.03.2016, 17:02
А если запускать MySub по условию? Target это ячейка, которая изменилась, если Target = Ячейке, изменение которой вы отслеживаете, то запускаем MySub. Тогда второй вариант макроса не должен зацикливаться. Burk
0
 Аватар для Святой НякаЛайк
655 / 247 / 89
Регистрация: 28.10.2015
Сообщений: 526
05.03.2016, 20:48
Поиграйтесь с этим: три листа, у каждого простейшая процедурка типа
Visual Basic
1
2
3
Private Sub Worksheet_Change(ByVal Target As Range)
MySub
End Sub
На всех трех листах процедура нацелена на ячейку A1, но во всех случаях по разному обрабатываются условия вызова MySub. Очень рекомендю: пробуйте менять значения, удалять, выделять диапазон, включающий A1 и менять/стирать Delet'ом, словом, пробуйте всё, на что фантазии хватит. Там куча приколов зарыто! Играйтесь со всеми тремя листами, изучайте процедуры и их условия. Но не спрашивайте меня почему всё так, а не иначе
Вложения
Тип файла: xls My_Magic_Book!.xls (23.0 Кб, 83 просмотров)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
05.03.2016, 20:48
Помогаю со студенческими работами здесь

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

Запуск макроса при изменении ячейки
Как сделать чтобы при изменении одной или нескольких ячеек (B2,B3,B4,B5) запускался макрос который делал бы ячейку Н4 равную Е4 Я просто...

Запуск макроса при изменении значения ячейки
Как сделать так, чтобы макрос запускался, как только в ячейке изменится значение, оно вводится с клавиатуры.. Т.е., например, есть...

Запуск/продолжение выполнения макроса по изменению ячейки
Доброго времени суток! Изучаю VBA самостоятельно ввиду необходимости использования его на работе. Подскажите пожалуйста есть ли...

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


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru