Como implementar um atraso/espera no VBA
A necessidade é um fato e pouca documentação há sobre isso. De fato as linguagens de programação mais usadas gozam facilmente de um método Sleep, que facilmente pausa a execução do código por algum momento.
No VBA isso não é tão intuitivo, mas existem algumas alternativas para fazê-lo.
Método 1: Usar um loop For… Next vazio
Uma desvantagem para este método é que não existe como determinar a quantidade exata de tempo que o programa leva para executar o executar um loop. A quantidade de tempo depende da velocidade do seu computador. O seguinte código executa um loop que faz nada, mas segura o processamento por algum tempo.
1 2 3 4 | Sub MyDelayMacro For iCount = 1 to 1000 Next iCount End Sub |
Método 2: Usar uma chamada API para suspender a execução Word
Utilizar um chamar API para suspender a execução por uma quantidade fixa de tempo.
O kernel32 contém uma função que pausa execução um programa do para uma quantidade especificada de tempo em milissegundos. Para que você possa usar a função, ele deve primeiro ser declarado na seção General Declarations do módulo no qual será usado:
1 2 | Declare Sub Sleep Lib "kernel32" Alias "Sleep" _ (ByVal dwMilliseconds As Long) |
Use a seguinte sintaxe para chamar a função Sleep :
1 2 3 | Sub Sleep() Sleep 1000 'Faz o código esperar por 1 segundo End Sub |
Método 3: Usar o método OnTime
Use o método OnTime para definir uma quantidade de tempo a pausa. O método OnTime usa a seguinte sintaxe:
Por requerer nome de uma macro para o argumento nome executar, você deve criar duas macros: a primeira macro para conter o chamar método OnTime e outros comandos relevantes para sua macro, e a segunda macro para executar quando o tempo alocado tiver passado. A segunda macro pode ser uma macro “fantasma” que não fará nada além de chamar o método OnTime para fazer o agendameto..
Este exemplo executa o macro nomeado ” MyDelayMacro ” 15 segundos desde o tempo é o exemplo executar.
1 2 3 4 5 6 7 8 9 | Sub MyMainMacro() ' Pausa por 15 segundos. Application.OnTime When:=Now + TimeValue("00:00:15"), _ Name:="MyDelayMacro" End Sub Public Sub MyDelayMacro() ' Macro executada sob o agendamento. MsgBox "Esta macro foi executada após 15 segundos." End Sub |
Método 4: Usar o método Application.Wait
Trabalha da mesma similar ao Sleep, porém é preciso “montar” um objeto TimeValue a ser passado com parâmetro, e o código esperará até o tempo definido neste para executar, simulando um comportamente de “esperar até”, ao contrário do Sleep que tem um comportamento “esperar por X tempo”
1 2 3 4 5 6 7 | Sub MyWaitMacro() newHour = Hour(Now()) newMinute = Minute(Now()) newSecond = Second(Now()) + 3 waitTime = TimeSerial(newHour, newMinute, newSecond) Application.Wait waitTime End Sub |
Para obter mais informações sobre como usar o método OnTime, leia este artigo: http://www.tomasvasquez.com.br/artigos/Agendando_a_execucao_de.html
Abraços
Tomás Vásquez
http://www.tomasvasquez.com.br/
Fontes:
http://support.microsoft.com
http://www.juliobattisti.com.br/forum/forum_posts.asp?TID=16484

23 Convidados
3 Bots
março 22nd, 2009 at 19:18
Me ajuda, não consigo utilizar o Application.ontime dentro do userform. O problema é que ele funciona, mas não chama a sub que eu peço.
Eu preciso é que a rotina espere um tempo e execute uma sub.
Pode me ajudar ?
março 23rd, 2009 at 10:03
Bruno,
Onde está a rotina que quer chamar? Dentro do código do Form? Em um módulo? Se for isso, ela está declarada como Public? Ela é uma Sub?
Abraços
Tomás
março 23rd, 2009 at 18:44
Oi Tomás,
Estou desenvolvendo uma macro que navega entre páginas de um website. Será que vc saberia como faço para que um determinado trecho de código seja executado apenas depois que uma determinada página for carregada? Não posso usar nenhuma das opções acima por serem muito estáticas, e o carregamento de uma página no browser varia de acordo com diversos parâmetros (velocidade conexão, processador, e outros).
Agradeço se puder ajudar.
março 24th, 2009 at 11:25
Adriana,
É possível saber através do VBA trabalhando com o objeto Internet Explorer se a página já foi carregada completamente. Dê uma olhada neste post e veja se resta alguma dúvida:
http://www.tomasvasquez.com.br/blog/microsoft-office/vba-interagindo-com-o-objeto-internet-explorer
Abraços
Tomás
março 24th, 2009 at 17:27
Oi,
Desculpe, pois eu realmente não conheco muita coisa de vba e preciso disso para finalizar um projeto.
Dei uma olhada no post que você sugeriu, mas não entendi o que seria o READYSTATE_COMPLETE, pois ao depurar, percebi que não possuia valor, travando a minha aplicação, e pesquisando na internet algumas pessoas atribuem o valor 4, e dessa maneira a aplicação não aguarda o carregamento completo da página.
Você pode me esclarecer esta dúvida?
Agradeço.
julho 1st, 2009 at 12:08
Estou tentando utilizar o Application.ontime porem indica que eu não possuo ele,
Public Sub IniciarTeste()
Alarme = Now TimeSerial(0, 0, IntervaloSegundos)
Application.OnTime EarliestTime:=Alarme, procedure:=”Macro1″, schedule:=True
Application
End Sub
Public Sub Macro1()
‘As suas rotinas
MsgBox “Olá!!! voltarei pelas ” & Format(Alarme, “hh:mm:ss”), _
vbInformation, “Timer em Vba”
Call IniciarTeste
End Sub
Public Sub PararTeste()
On Error Resume Next
Application.OnTime EarliestTime:=Alarme, _
procedure:=”Macro1″, _
schedule:=False
End Sub
Esta tudo declarado dentro de um formulário, isto esta correto?
Tenho que declarar em outro lugar ou algo assim?
Por que ele indica pra mim que não tenho o OnTime no meu projeto?
Att
Thomas
julho 1st, 2009 at 14:16
Thomas,
É preciso entender o que quer realmente fazer. No seu código, aparentemente há uma referência circular e isso deve ser tratado.
Respondendo a algumas perguntas:
Esta tudo declarado dentro de um formulário, isto esta correto?
O OnTime funcionará da mesma forma. Porém, é uma “boa prática” deixar funções em Módulos separados
Tenho que declarar em outro lugar ou algo assim?
Respondido acima
Por que ele indica pra mim que não tenho o OnTime no meu projeto?
Provável que haja algum erro no código. A função OnTime é nativa do VBA quando acesso pela maioria das aplicações do Office.
Abraços
Tomás
julho 1st, 2009 at 16:04
Thomas,
Acabei de publicar um artigo que explica como funciona o método OnTime. Dê uma olhada:
http://www.tomasvasquez.com.br/blog/microsoft-office/vba-agendando-a-execucao-de-macros-com-a-funcao-ontime
Abraços
Tomás