Como Fazer Loop While VBA Excel

Neste artigo você aprenderá como fazer loop while VBA no Excel.

O loop é o código de programação utilizado para realizar uma série de operações uma quantidade determinada de vezes.

Este é um procedimento usado em todas as linguagens de programação e é muito útil.

No caso do VBA no Excel não é diferente, usamos para diversas finalidades.

No exemplo deste artigo você aprenderá como gerar uma lista de arquivos PDF ou imprimir, alterando os dados e gerando um por um mudando os valores à partir de uma lista.

Relatório de Cobrança Excel

No nosso exemplo temos um relatório de cobrança, de reparte de bancas de jornais.

Nele nós temos os produtos, quantidades, períodos que temos em cada um dos clientes para cobrança.

Ali temos fórmulas que alteram automaticamente ao mudar o cliente no topo, aonde temos o CLIENTE 395.

Aprender Loop While VBA Excel 1

No nosso exemplo temos uma lista de Clientes com os dados como vemos abaixo:

Aprender Loop While VBA Excel 2

Na lista de Repartes temos os dados dos lançamentos, como é no caso o Ponto, Produto, Data e Qtde.

O primeiro campo é um campo chave, criado para fazermos um PROCV de chave concatenada.

Aprender Loop While VBA Excel 3

Como vemos acima temos na coluna Chave uma ligação entre os campos 1, 2 e 3 para criar a chave.

Na pasta de trabalho temos a planliha abaixo, aonde temos os dados mudando conforme é selecionado o cliente no topo da planilha:

Aprender Loop While VBA Excel 4

Assim, ao mudar temos os valores mudando de todos os produtos como vemos abaixo:

Aprender Loop While VBA Excel 5

Então o nosso objetivo com o Loop é mudar o cliente no topo e mandar gerar em PDF ou imprimir.

Como Fazer Loop While no VBA Excel

Para isso o primeiro passo é habilitar a guia desenvolvedor.

Depois clique na guia Desenvolvedor e clique no botão Visual Basic.

Nele clique em Inserir->Módulo, irá ficar como abaixo:

Aprender Loop While VBA Excel 7

Após isso cole o código abaixo VBA que é detalhado também no VBA passo-a-passo, além dos comentários que temos no VBA.

Public Sub lsGerar()
    On Error GoTo TratarErro
    
    Dim iTotalLinhas    As Long
    Dim iLinhas         As Long
    
    'Quantas Linhas no loop
    iTotalLinhas = Clientes.ListObjects("tClientes").ListColumns(1).DataBodyRange.Count + 7
    
    'Inicia a linha
    iLinhas = 8
    
    'Loop gerando em pdf
    While iLinhas <= iTotalLinhas
        'Atualiza o cliente no relatório
        Relatorio.Range("E4").Value = Clientes.Range("B" & iLinhas).Value
        
        'PDF
        ActiveSheet.ExportAsFixedFormat Type:=xlTypePDF, Filename:= _
            "C:\Rieper\Blog Guia do Excel\059 - Loop Excel\" & Clientes.Range("B" & iLinhas).Value & ".pdf", Quality:= _
            xlQualityStandard, IncludeDocProperties:=True, IgnorePrintAreas:=False, _
            OpenAfterPublish:=False
            
        'Impressão
        'ActiveWindow.SelectedSheets.PrintOut Copies:=1, Collate:=True, _
            IgnorePrintAreas:=False
    
       iLinhas = iLinhas + 1
    Wend

Sair:
    Exit Sub
TratarErro:
    MsgBox "Houve um erro na impressão", vbCritical
    GoTo Sair
End Sub

Pronto, após isso já temos o código pronto para gerar o PDF à partir do Loop While.

Ao executar este código ele irá passar por todas as linhas da lista de clientes e trocará os clientes um a um e irá gerar em PDF.

No código tem também como imprimir.

Baseado no código VBA acima pode adaptar este código e o utilizar para outras necessidades de loop.

Download Planilha Loop While VBA Excel

Clique no botão abaixo para realizar o  download do arquivo de exemplo:

Baixe a planilha


Marcos Rieper

Pai, marido, professor e consultor em Excel.

Obrigado por ler este artigo, este blog foi criado para difundir o conhecimento em Excel à todos.

Divulgamos novos artigos nas redes sociais, basta clicar nos ícones abaixo.

Excel não precisa ser complicado

Assine nossa newsletter e receba dicas práticas para dominar o excel