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:  
S.Morganth

Contador de hora parando ao alternar planilhas !

Recommended Posts

Boa Tarde, 

Possuo uma planilha do excel com o VBA no fim da mensagem, ondem possui um contador de tempo e linha vai atualizando de tempos em tempos.

Acontece que trabalho com mais duas planilhas abertas, então se eu selecionar a outra planilha, essa que tem o contador para de contar e executar a macro ! 

Como corrigir isso para que não aconteça ?

Muito Obrigado ! 

 

Dim contador As Integer

Sub Start()


If Range("G3").Value = "Aberto" Then
    Application.OnTime Now + TimeValue("00:00:01"), "Cron"
    Application.OnTime Now + TimeValue("00:00:01"), "Inserção_Dados"
    End If
    

End Sub

Sub Cron()

If Range("G3").Value = "Aberto" Then
    Range("B3").Value = Now
    Application.OnTime Now + TimeValue("00:00:01"), "Cron"

    
     
End If
End Sub

Sub Inserção_Dados()

If Range("B3").Value <> Range("B4").Value Then

Rows("4:10").Value = Rows("3:9").Value
Range("C3").Value = Range("F4").Value
Range("D3").Value = Range("F4").Value
Range("E3").Value = Range("F4").Value
Application.OnTime Now + TimeValue("00:00:10"), "Inserção_Dados"

End If
End Sub

 

MOD PLANILHA AUTOMATICA.zip

Compartilhar este post


Link para o post
Compartilhar em outros sites

@S.Morganth, boa noite.

 

Quando você trabalha com mais de uma pasta de trabalho excel aberta é fundamental que você qualifique todos os intervalos em seu código, pois o VBA sempre irá buscar o objeto que está ativo. Quando você abriu um outro arquivo, como o Workbook ativo deixou de ser o que estava rodando o código, a macro irá buscar os ranges nesse novo arquivo.

Então, ao invés de Range("G3").Value, por exemplo, você poderia usar:

ThisWorkbook.Worksheets("Planilha1").Range("G3").Value

ThisWorkbook é sempre a pasta que está rodando o código.

 

Se tiver que qualificar muitos ranges, pra não poluir muito seu código e não ter que ficar qualificando de um em um, você pode usar With, por exemplo:

  With ThisWorkbook.Worksheets("Planilha1")

      If .Range("B3").Value <> .Range("B4").Value Then

         .Rows("4:10").Value = .Rows("3:9").Value

          blá, blá, blá

      End If

  End With
Note o ponto antes de Range e de Rows.

 

Ou melhor ainda, criar uma variável que sempre se refira à planilha da pasta alvo e aí qualificar o Range por esta variável. Por exemplo:

Sub Inserção_Dados()
  Dim ws As Worksheet
  Set ws = ThisWorkbook.Worksheets("Planilha1")
    If ws.Range("B3").Value <> ws.Range("B4").Value Then

        blá, blá, blá

    End If

   ...

End Sub

 

  • Curtir 1

Compartilhar este post


Link para o post
Compartilhar em outros sites
  • Autor do tópico
  • Muito Obrigado pela ajuda, vou testar aqui !! 

    Abração ! 

    Compartilhar este post


    Link para o post
    Compartilhar em outros sites

    Crie uma conta ou entre para comentar

    Você precisar ser um membro para fazer um comentário






    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

    ×