Como executar uma macro quando o valor da célula muda no Excel?
Normalmente, no Excel, podemos pressionar a tecla F5 ou o botão Executar para executar o código VBA. Mas você já tentou executar um código de macro específico quando o valor de uma célula muda? Neste artigo, vou apresentar alguns truques rápidos para lidar com essa tarefa no Excel.
Executar ou chamar uma macro quando o valor de uma célula específica muda com código VBA
Executar ou chamar uma macro quando o valor de qualquer célula muda em um intervalo com código VBA
Executar ou chamar uma macro quando o valor de uma célula específica muda com código VBA
Para executar um código de macro alterando o valor de uma célula, o seguinte código VBA pode ajudá-lo, por favor, faça o seguinte:
1. Clique com o botão direito do mouse na guia da planilha onde deseja executar a macro se o valor da célula mudar e escolha Visualizar Código no menu de contexto; na janela aberta do Microsoft Visual Basic for Applications, copie e cole o seguinte código no Módulo em branco:
Código VBA: Executar macro quando o valor da célula muda:
Private Sub Worksheet_Change(ByVal Target As Range)
If Target.Address = "$A$1" Then
Call Mymacro
End If
End Sub
Observação: No código acima, A1 é a célula específica que você deseja usar como base para executar o código, Mymacro é o nome da macro que você deseja executar. Altere-os conforme necessário.
2. Em seguida, salve e feche a janela de código. Agora, ao inserir ou alterar o valor na célula A1, o código específico será acionado imediatamente.
Executar ou chamar uma macro quando o valor de qualquer célula muda em um intervalo com código VBA
Se você deseja executar ou acionar uma macro quando o valor de qualquer célula mudar em um intervalo de células, o seguinte código pode ajudá-lo.
1. Clique com o botão direito do mouse na guia da planilha onde deseja executar a macro se o valor da célula mudar e escolha Visualizar Código no menu de contexto; na janela aberta do Microsoft Visual Basic for Applications, copie e cole o seguinte código no Módulo em branco:
Código VBA: Executar macro quando o valor de qualquer célula muda em um intervalo:
Private Sub Worksheet_Change(ByVal Target As Range)
If Not Intersect(Target, Range("A1:B100")) Is Nothing Then
Call Mymacro
End If
End Sub
Observação: No código acima, A1:B100 são as células específicas que você deseja usar como base para executar o código, Mymacro é o nome da macro que você deseja executar. Altere-os conforme necessário.
2. Em seguida, salve e feche a janela de código. Agora, ao inserir ou alterar o valor em qualquer célula de A1:B100, o código específico será executado imediatamente.
Remover todas as macros de várias pastas de trabalho
O utilitário Remover Todas as Macros em Lote do Kutools para Excel pode ajudá-lo a remover todas as macros de várias pastas de trabalho conforme necessário. Baixe e experimente gratuitamente o Kutools para Excel agora!
Kutools para Excel: com mais de 300 complementos úteis para o Excel, grátis para testar sem limitações por 30 dias. Baixe e experimente agora!
Artigos relacionados:
Como executar uma macro automaticamente antes de imprimir no Excel?
Como executar uma macro com base no valor da célula no Excel?
Como executar uma macro com base no valor selecionado na lista suspensa no Excel?
Como executar uma macro clicando em hiperlinks no Excel?
Como executar uma macro quando uma planilha é selecionada de uma pasta de trabalho?
Melhores Ferramentas de Produtividade para Office
Potencialize suas habilidades no Excel com o Kutools para Excel e experimente uma eficiência sem igual. O Kutools para Excel oferece mais de300 recursos avançados para aumentar sua produtividade e economizar tempo. Clique aqui para obter o recurso que você mais precisa...
O Office Tab traz interface com abas para o Office e facilita muito o seu trabalho
- Habilite a edição e leitura com abas no Word, Excel, PowerPoint, Publisher, Access, Visio e Project.
- Abra e crie vários documentos em novas abas na mesma janela, em vez de abrir novas janelas.
- Aumente sua produtividade em50% e reduza centenas de cliques do mouse todos os dias!