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
  • Autor do tópico
  • 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
  • Autor do tópico
  • 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
  • Autor do tópico
  • 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
  • Autor do tópico
  • 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
  • Autor do tópico
  • 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

    ×