Ir ao conteúdo
  • Comunicados

    • Gabriel Torres

      Seja um moderador do Clube do Hardware!   12-02-2016

      Prezados membros do Clube do Hardware, Está aberto o processo de seleção de novos moderadores para diversos setores ou áreas do Clube do Hardware. Os requisitos são:   Pelo menos 500 posts e um ano de cadastro; Boa frequência de participação; Ser respeitoso, cordial e educado com os demais membros; Ter bom nível de português; Ter razoável conhecimento da área em que pretende atuar; Saber trabalhar em equipe (com os moderadores, coordenadores e administradores).   Os interessados deverão enviar uma mensagem privada para o usuário @Equipe Clube do Hardware com o título "Candidato a moderador". A mensagem deverá conter respostas às perguntas abaixo:   Qual o seu nome completo? Qual sua data de nascimento? Qual sua formação/profissão? Já atuou como moderador em algo outro fórum, se sim, qual? De forma sucinta, explique o porquê de querer ser moderador do fórum e conte-nos um pouco sobre você.   OBS: Não se trata de função remunerada. Todos que fazem parte do staff são voluntários.
    • DiF

      Poste seus códigos corretamente!   21-05-2016

      Prezados membros do Fórum do Clube do Hardware, O Fórum oferece um recurso chamado CODE, onde o ícone no painel do editor é  <>     O uso deste recurso é  imprescindível para uma melhor leitura, manter a organização, diferenciar de texto comum e principalmente evitar que os compiladores e IDEs acusem erro ao colar um código copiado daqui. Portanto convido-lhes para ler as instruções de como usar este recurso CODE neste tópico:  
Entre para seguir isso  
FabianoLothor

[Resolvido] Realizar cálculos como uma espécie de máscara da célula

Recommended Posts

Boa noite!

Gostaria de saber se tem como eu realizar cálculos com a utilização de máscaras ou se existe alguma forma de resolver este problema.

Apesar do problema ser um pouco mais complexo, vou simplificá-lo para ficar de fácil entendimento, pois sabendo como fazer eu já consigo fazer o que eu quero.

Suponha que o valor da célula A1 é igual a 2.

Eu quero que quando alguém digite um valor na célula A2, este valor seja igual ao valor digitado mais o valor de A1, ou seja, se eu digitar 1 na célula A2 o valor de A2 seria 3 ao invés de 1.

Tentei usar máscaras, mas não consegui fazer o cálculo, ao invés de ficar 3 fica 1+2. :(

Eu consigo - obviamente - fazer com que A3 seja igual a soma de A1+A2, mas isso é inviável para o caso, tem como resolver de outra forma?

Compartilhar este post


Link para o post
Compartilhar em outros sites

Bom dia FAbiano

Eu não entendi muito bem o que você quer mas vou arriscar uma sugestão:

Copie e cole está fórmula na célula A2 =SE(A1="";"";A1+2)

Com a utilização desta fórmula se a célula A1 ficar vazia a célula 2 também ficará.

Dê retorno.

Um abraço.

Compartilhar este post


Link para o post
Compartilhar em outros sites
Bom dia FAbiano

Eu não entendi muito bem o que você quer mas vou arriscar uma sugestão:

Copie e cole está fórmula na célula A2 =SE(A1="";"";A1+2)

Com a utilização desta fórmula se a célula A1 ficar vazia a célula 2 também ficará.

Dê retorno.

Um abraço.

Patropi, desculpe não ter sido claro em minha pergunta anterior, o que você postou não é o que eu quero. Vou tentar ser mais direto agora...

* Eu quero incrementar o valor que eu digitar em A2 com o valor de A1.

- Como no exemplo anterior:

. Suponha que A1 é igual a 2.

. Agora suponha que o usuário digitou 3 em A2.

. O que eu quero é que o valor de A2 seja 3+2 (ou seja, A2+A1).

. Se A1 for igual a 3, e o usuário digitar 1 em A2, o valor de A2 deve ser 4.

Entendeu?

Eu não quero fazer na célula A3 por exemplo A1+A2 eu quero fazer na própria célula A2. Como se eu fizesse um cálculo na máscara.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Fabiano

Agora eu entendi o que você quer.

Não tem como fazer uma soma aparecer na mesma célulade onde vem um dos valores somados sem o uso de VBA.

Com fórmulas o que você pode fazer é usar uma coluna auxiliar e depois deixá-la oculta.

Um abraço

Compartilhar este post


Link para o post
Compartilhar em outros sites
Fabiano

Agora eu entendi o que você quer.

Não tem como fazer uma soma aparecer na mesma célulade onde vem um dos valores somados sem o uso de VBA.

Com fórmulas o que você pode fazer é usar uma coluna auxiliar e depois deixá-la oculta.

Um abraço

Sabes como fazer? Poderia me ajudar? Não entendo nada de VBA.

Compartilhar este post


Link para o post
Compartilhar em outros sites

Fabiano, veja se é isso

cole o código no módulo da planilha: clique com o direito na Guia da planilha, clique em "Exibir código", cole na janela em branco que se abrirá

Private Sub Worksheet_Change(ByVal Target As Range)
If Target.Address <> "$A$2" Or _
Not IsNumeric(Target.Value) Or Target.Count > 1 _
Or Not IsNumeric(Cells(1, 1).Value) Then Exit Sub
Application.EnableEvents = False
Target.Value = Target.Value + Cells(1, 1).Value
Application.EnableEvents = True
End Sub

Compartilhar este post


Link para o post
Compartilhar em outros sites
Fabiano, veja se é isso

cole o código no módulo da planilha: clique com o direito na Guia da planilha, clique em "Exibir código", cole na janela em branco que se abrirá

Private Sub Worksheet_Change(ByVal Target As Range)
If Target.Address <> "$A$2" Or _
Not IsNumeric(Target.Value) Or Target.Count > 1 _
Or Not IsNumeric(Cells(1, 1).Value) Then Exit Sub
Application.EnableEvents = False
Target.Value = Target.Value + Cells(1, 1).Value
Application.EnableEvents = True
End Sub

:)

É exatamente isso osvaldomp, agora só preciso daptar o código a minha planilha. Se eu quiser fazer exatamente isso em outras células, o que eu vou alterar no seu código além de "$A$2"?

Compartilhar este post


Link para o post
Compartilhar em outros sites

você quer dizer que o valor inserido em qualquer célula da planilha, com exceção para a linha 1, seja adicionado do valor da célula imediatamente acima, seria isso ?

Compartilhar este post


Link para o post
Compartilhar em outros sites
você quer dizer que o valor inserido em qualquer célula da planilha, com exceção para a linha 1, seja adicionado do valor da célula imediatamente acima, seria isso ?

Não.

Eu pedi para que exemplificassem na célula A2 como funcionaria se eu quizesse que a soma fosse feita com a célula A1, para facilitar o exemplo.

Mas e se eu quiser fazer o mesmo que eu fiz na célula A2 com as células J5 e J6 onde seus valores serão a soma do número digitado mais o valor de J4?

* Exemplo:

- J4 = 5

- Usuário em J5 digita 3, J5 = 8.

- Usuário em J6 digita 1, J6 = 6.

Compartilhar este post


Link para o post
Compartilhar em outros sites

* Exemplo:

- J4 = 5

- Usuário em J5 digita 3, J5 = 8.

- Usuário em J6 digita 1, J6 = 6.

generalizando o seu exemplo para toda a planilha teremos 3 situações:

1. o valor inserido não será alterado (seria uma célula qualquer da planilha sendo tratada como no seu ex. a célula equivalente à J4)

2. o valor inserido será adicionado do valor da primeira célula acima (J5)

3. o valor inserido será adicionado do valor da segunda célula acima (J6)

então, será necessário que você estabeleça critérios para o código identificar em qual das 3 situações a inserção será enquadrada

por exemplo, se houver uma inserção em M45, o código deverá:

1. manter o valor inserido ou

2. adicionar o valor de M44 ou

3. adicionar o valor de M43 ?

Compartilhar este post


Link para o post
Compartilhar em outros sites
generalizando o seu exemplo para toda a planilha teremos 3 situações:

1. o valor inserido não será alterado (seria uma célula qualquer da planilha sendo tratada como no seu ex. a célula equivalente à J4)

2. o valor inserido será adicionado do valor da primeira célula acima (J5)

3. o valor inserido será adicionado do valor da segunda célula acima (J6)

então, será necessário que você estabeleça critérios para o código identificar em qual das 3 situações a inserção será enquadrada

por exemplo, se houver uma inserção em M45, o código deverá:

1. manter o valor inserido ou

2. adicionar o valor de M44 ou

3. adicionar o valor de M43 ?

Você não entendeu o que eu quis dizer, mas tudo bem, programo em outras linguagens, mas nunca programei em VBA (ou VB), porém analisando seu código eu achei o que deve ser mudado para funcionar em outras células.

Preciso apenas mudar o que está em negrito...

Private Sub Worksheet_Change(ByVal Target As Range)

If Target.Address <> "$A$2" Or _

Not IsNumeric(Target.Value) Or Target.Count > 1 _

Or Not IsNumeric(Cells(1, 1).Value) Then Exit Sub

Application.EnableEvents = False

Target.Value = Target.Value + Cells(1, 1).Value

Application.EnableEvents = True

End Sub

Se por exemplo eu quiser que ao invés da célula A2 incremente o valor de A1, eu quiser que B2 incremente o valor de B1, eu coloco nas partes em negrito respectivamente "$B$2", (1, 2), (1, 2).

Agora para o meu exemplo do J que citei acima ficaria respectivamente: "$J$5", (4, 10), (4, 10).

Sendo assim... Resolvi o meu problema, muito obrigado osvaldo, podem fechar o tópico.

Editado por FabianoLothor

Compartilhar este post


Link para o post
Compartilhar em outros sites

Caso o autor do tópico necessite, o mesmo será reaberto, para isso deverá entrar em contato com a moderação solicitando o desbloqueio.

Compartilhar este post


Link para o post
Compartilhar em outros sites
Visitante
Este tópico está impedido de receber novos posts.
Entre para seguir isso  





Sobre o Clube do Hardware

No ar desde 1996, o Clube do Hardware é uma das maiores, mais antigas e mais respeitadas publicações 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

×