Ir ao conteúdo
  • Cadastre-se

Excel VBA - AfterUpdate com condicional


Ir à solução Resolvido por AfonsoMira,

Posts recomendados

Olá!
Preciso de uma ajuda que, acredito eu ser simples, mas não estou conseguindo chegar no resultado.

São 4 textbox (1, 2, 3, 4)

 

Se o valor da textbox1 for < 0: multiplica a textbox2 pela textbox1

Se o valor da textbox1 for >=0: multiplica a textbox 2 pela texbox3

 

O resultado dessa conta ficará na textbox4.

 

Na planilha anexa fiz a conta com fórmula, mas preciso que o cálculo seja pelo form.

 

Alguém conseguiria me ajudar?

Pasta1.zip

Link para o comentário
Compartilhar em outros sites

  • Solução

Boas @Luciana Goes,

 

Substitua todo o seu código por esse: 

Private Sub UserForm_Initialize()
    TextBox1.Text = Plan1.Range("b3").Value
    TextBox2.Text = Plan1.Range("c3").Value
    TextBox3.Text = Plan1.Range("d3").Value
    TextBox1_AfterUpdate
End Sub


Private Sub TextBox1_AfterUpdate()

valor2 = Right(TextBox2.Value, Len(TextBox2.Value) - 3)

If TextBox1.Value < 0 Then
    TextBox4.Value = valor2 * CDbl(TextBox1.Value)
ElseIf TextBox1.Value >= 0 Then
    TextBox4.Value = valor2 * TextBox3.Value
End If

End Sub

Private Sub TextBox2_Change()
    TextBox2.Value = VBA.Format(TextBox2.Value, "R$ ###,##0.00")
    TextBox2.TabStop = False
End Sub

 

Espero ter ajudado.

Link para o comentário
Compartilhar em outros sites

Crie uma conta ou entre para comentar

Você precisa ser um usuário para fazer um comentário

Criar uma conta

Crie uma nova conta em nossa comunidade. É fácil!

Crie uma nova conta

Entrar

Já tem uma conta? Faça o login.

Entrar agora

Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas comunidades sobre tecnologia do Brasil. Leia mais

Direitos autorais

Não permitimos a cópia ou reprodução do conteúdo do nosso site, fórum, newsletters e redes sociais, mesmo citando-se a fonte. Leia mais

×
×
  • Criar novo...