Instrução For...Next

Repete as instruções entre o bloco For...Next um número especificado de vezes.

Sintaxe:


For counter=start To end [Step step]
bloco de instruções
[Exit For]
bloco de instruções
Next [counter]

Variáveis:

Contador: o contador de ciclos atribuiu inicialmente o valor à direita do sinal de igual (início). Só são válidas as variáveis numéricas. O contador de ciclos aumenta ou diminui de acordo com a variável Passo até que Fim seja transferido.

Início: variável numérica que define o valor inicial no início do ciclo.

Fim: variável numérica que define o valor final ao terminar o ciclo.

Passo: define o valor de referência para aumentar ou diminuir o contador de ciclos. Se Passo não for especificado, o contador de ciclos é incrementado em 1. Neste caso, Fim terá de ser maior do que Início. Se quiser diminuir o Contador, Fim terá de ser menor do que Início e Passo terá de receber um valor negativo.

O ciclo For...Next repete todas as instruções no ciclo durante o número de vezes especificado pelos parâmetros.

À medida que a variável do contador diminui, o LibreOffice Basic verifica se o valor final já foi atingido. Assim que o contador ultrapassa o valor final, o ciclo termina automaticamente.

É possível imbricar instruções For...Next. Se não especificar uma variável a seguir à instrução Next, Next consulta automaticamente a instrução For mais recente.

Se especificar um incremento de 0, as instruções entre For e Next repetem-se continuamente.

Ao contar a variável do contador, o LibreOffice Basic verifica se não ocorre uma ultrapassagem de capacidade ou ultrapassagem de capacidade por defeito. O ciclo termina quando o Contador excede Fim (valor Passo positivo) ou é menor que Fim (valor Passo negativo).

Utilize a instrução Exit For para terminar o ciclo incondicionalmente. Esta instrução terá de estar num ciclo For...Next. Utilize a instrução If...Then para testar a condição de fim como se segue:

For...

instruções

If condição = Verdade Then Exit For

instruções

Next

Nota: Em ciclos imbricados For...Next, se sair de um ciclo incondicionalmente com Exit for, só é terminado um ciclo.

Exemplo

O seguinte exemplo utiliza dois ciclos imbricados para ordenar uma matriz em cadeia com 10 elementos ( sEntry() ), que são primeiro preenchidos com diversos conteúdos:


Sub ExampleSort
Dim sEntry(9) As String
Dim iCount As Integer
Dim iCount2 As Integer
Dim sTemp As String
    sEntry(0) = "João"
    sEntry(1) = "Patrícia"
    sEntry(2) = "Carlos"
    sEntry(3) = "Tomás"
    sEntry(4) = "Miguel"
    sEntry(5) = "David"
    sEntry(6) = "Catarina"
    sEntry(7) = "Susana"
    sEntry(8) = "Eduardo"
    sEntry(9) = "Cristina"
    For iCount = 0 To 9
        For iCount2 = iCount + 1 To 9
            If sEntry(iCount) > sEntry(iCount2) Then
                sTemp = sEntry(iCount)
                sEntry(iCount) = sEntry(iCount2)
                sEntry(iCount2) = sTemp
            End If
        Next iCount2
    Next iCount
    For iCount = 0 To 9
        Print sEntry(iCount)
    Next iCount
End Sub