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