Delen via


about_For

Korte beschrijving

Beschrijft een taalopdracht die u kunt gebruiken om instructies uit te voeren op basis van een voorwaardelijke test.

Lange beschrijving

De For instructie (ook wel een For lus genoemd) is een taalconstructie die u kunt gebruiken om een lus te maken waarmee opdrachten in een opdrachtblok worden uitgevoerd terwijl een opgegeven voorwaarde resulteert in $true.

Een typisch gebruik van de For lus is het herhalen van een matrix met waarden en het uitvoeren van een subset van deze waarden. Als u in de meeste gevallen alle waarden in een matrix wilt herhalen, kunt u overwegen een Foreach instructie te gebruiken.

Syntaxis

Hieronder ziet u de syntaxis van de For instructie.

for (<Init>; <Condition>; <Repeat>)
{
    <Statement list>
}

De tijdelijke aanduiding Init vertegenwoordigt een of meer opdrachten die worden uitgevoerd voordat de lus begint. Doorgaans gebruikt u het Init-gedeelte van de instructie om een variabele te maken en te initialiseren met een beginwaarde.

Deze variabele is vervolgens de basis voor de voorwaarde die moet worden getest in het volgende gedeelte van de For instructie.

De tijdelijke aanduiding Voorwaarde vertegenwoordigt het gedeelte van de For instructie dat wordt omgezet in een $true of $false Booleaanse waarde. PowerShell evalueert de voorwaarde telkens wanneer de For lus wordt uitgevoerd. Als de instructie is $true, worden de opdrachten in het opdrachtblok uitgevoerd en wordt de instructie opnieuw geëvalueerd. Als de voorwaarde nog steeds $trueis, worden de opdrachten in de lijst Instructie opnieuw uitgevoerd. De lus wordt herhaald totdat de voorwaarde wordt $false.

De tijdelijke aanduiding Herhalen vertegenwoordigt een of meer opdrachten, gescheiden door komma's, die telkens worden uitgevoerd wanneer de lus wordt herhaald. Dit wordt meestal gebruikt om een variabele te wijzigen die wordt getest in het onderdeel Voorwaarde van de instructie.

De tijdelijke aanduiding voor de instructielijst vertegenwoordigt een set van een of meer opdrachten die worden uitgevoerd telkens wanneer de lus wordt ingevoerd of herhaald. De inhoud van de lijst Met instructies wordt omgeven door accolades.

Ondersteuning voor meerdere bewerkingen

De volgende syntaxis wordt ondersteund voor meerdere toewijzingsbewerkingen in de Init-instructie :

# Comma separated assignment expressions enclosed in parentheses.
for (($i = 0), ($j = 0); $i -lt 10; $i++)
{
    "`$i:$i"
    "`$j:$j"
}

# Sub-expression using the semicolon to separate statements.
for ($($i = 0;$j = 0); $i -lt 10; $i++)
{
    "`$i:$i"
    "`$j:$j"
}

De volgende syntaxis wordt ondersteund voor meerdere toewijzingsbewerkingen in de instructie Repeat :

# Comma separated assignment expressions.
for (($i = 0), ($j = 0); $i -lt 10; $i++, $j++)
{
    "`$i:$i"
    "`$j:$j"
}

# Comma separated assignment expressions enclosed in parentheses.
for (($i = 0), ($j = 0); $i -lt 10; ($i++), ($j++))
{
    "`$i:$i"
    "`$j:$j"
}

# Sub-expression using the semicolon to separate statements.
for ($($i = 0;$j = 0); $i -lt 10; $($i++;$j++))
{
    "`$i:$i"
    "`$j:$j"
}

Notitie

Bewerkingen die niet vooraf of na incrementeel zijn, werken mogelijk niet met alle syntaxis.

Voor meerdere voorwaarden worden logische operators gebruikt, zoals wordt gedemonstreerd in het volgende voorbeeld.

for (($i = 0), ($j = 0); $i -lt 10 -and $j -lt 10; $i++,$j++)
{
    "`$i:$i"
    "`$j:$j"
}

Zie about_Logical_Operators voor meer informatie.

Voorbeelden van syntaxis

Minimaal vereist een For instructie het haakje rondom de Init, Voorwaarde en Herhalen van een deel van de instructie en een opdracht tussen accolades in het lijstgedeelte Van de instructie .

Houd er rekening mee dat in de komende voorbeelden opzettelijk code buiten de For instructie wordt weergegeven. In latere voorbeelden wordt code geïntegreerd in de For instructie.

Met de volgende For instructie wordt bijvoorbeeld voortdurend de waarde van de $i variabele weergegeven totdat u de opdracht handmatig uitbreekt door op Ctrl+C te drukken.

$i = 1
for (;;)
{
    Write-Host $i
}

U kunt extra opdrachten toevoegen aan de lijst met instructies, zodat de waarde van $i elke keer dat de lus wordt uitgevoerd, wordt verhoogd met 1, zoals in het volgende voorbeeld wordt weergegeven.

for (;;)
{
    $i++; Write-Host $i
}

Totdat u de opdracht uitbreekt door op Ctrl+C te drukken, wordt met deze instructie voortdurend de waarde van de $i variabele weergegeven, omdat deze met 1 wordt verhoogd telkens wanneer de lus wordt uitgevoerd.

In plaats van de waarde van de variabele in het overzichtslijstgedeelte van de For instructie te wijzigen, kunt u in plaats daarvan het gedeelte Herhalen van de For instructie als volgt gebruiken.

$i=1
for (;;$i++)
{
    Write-Host $i
}

Deze instructie wordt nog steeds voor onbepaalde tijd herhaald totdat u de opdracht uitbreekt door op Ctrl+C te drukken.

U kunt de For lus beëindigen met behulp van een voorwaarde. U kunt een voorwaarde plaatsen met behulp van het voorwaardegedeelte van de For instructie. De For lus $falsewordt beëindigd wanneer de voorwaarde wordt geëvalueerd.

In het volgende voorbeeld wordt de For lus uitgevoerd terwijl de waarde $i kleiner is dan of gelijk is aan 10.

$i=1
for(;$i -le 10;$i++)
{
    Write-Host $i
}

In plaats van de variabele buiten de For instructie te maken en initialiseren, kunt u deze taak binnen de For lus uitvoeren met behulp van het Init-gedeelte van de For instructie.

for($i=1; $i -le 10; $i++){Write-Host $i}

U kunt regelterugloop gebruiken in plaats van puntkomma's om de init-, voorwaarde- en herhalingsgedeelten van de For instructie te scheiden. In het volgende voorbeeld ziet u een For voorbeeld waarin deze alternatieve syntaxis wordt gebruikt.

for ($i = 0
  $i -lt 10
  $i++){
  $i
}

Deze alternatieve vorm van de For instructie werkt in PowerShell-scriptbestanden en bij de PowerShell-opdrachtprompt. Het is echter eenvoudiger om de syntaxis van de For instructie met puntkomma's te gebruiken wanneer u interactieve opdrachten invoert bij de opdrachtprompt.

De For lus is flexibeler dan de Foreach lus omdat u hiermee waarden in een matrix of verzameling kunt verhogen met behulp van patronen. In het volgende voorbeeld wordt de $i variabele verhoogd met 2 in het gedeelte Herhaling van de For instructie.

for ($i = 0; $i -le 20; $i += 2)
{
    Write-Host $i
}

De For lus kan ook op één regel worden geschreven, zoals in het volgende voorbeeld.

for ($i = 0; $i -lt 10; $i++) { Write-Host $i }

Functioneel voorbeeld

In het volgende voorbeeld ziet u hoe u een For lus kunt gebruiken om een matrix met bestanden te herhalen en de naam ervan te wijzigen. De bestanden in de work_items map hebben hun werkitem-id als bestandsnaam. De lus doorloopt de bestanden om ervoor te zorgen dat het id-nummer nul is opgevuld tot vijf cijfers.

Eerst haalt de code de lijst met gegevensbestanden van werkitems op. Ze zijn allemaal JSON-bestanden die de indeling <work-item-type>-<work-item-number> voor hun naam gebruiken. Als de bestandsgegevensobjecten zijn opgeslagen in de $fileList variabele, kunt u ze sorteren op naam en zien dat de volgorde van de items op id onverwacht is terwijl items zijn gegroepeerd op type.

$fileList = Get-ChildItem -Path ./work_items
$fileList | Sort-Object -Descending -Property Name
bug-219.json
bug-41.json
bug-500.json
bug-697.json
bug-819.json
bug-840.json
feat-176.json
feat-367.json
feat-373.json
feat-434.json
feat-676.json
feat-690.json
feat-880.json
feat-944.json
maint-103.json
maint-367.json
maint-454.json
maint-49.json
maint-562.json
maint-579.json

Om ervoor te zorgen dat u de werkitems alfanumerisch kunt sorteren, moeten de werkitemnummers nul worden opgevuld.

De code doet dit door eerst te zoeken naar het werkitem met het langste numerieke achtervoegsel. Het lust over de bestanden met behulp van een for lus, met behulp van de index voor toegang tot elk bestand in de matrix. Elke bestandsnaam wordt vergeleken met een patroon voor een reguliere expressie om het werkitemnummer te extraheren als een tekenreeks in plaats van een geheel getal. Vervolgens worden de lengten van de werkitemnummers vergeleken om het langste getal te vinden.

# Default the longest numeral count to 1, since it can't be smaller.
$longestNumeralCount = 1

# Regular expression to find the numerals in the filename - use a template
# to simplify updating the pattern as needed.
$patternTemplate = '-(?<WorkItemNumber>{{{0},{1}}})\.json'
$pattern         =  $patternTemplate -f $longestNumeralCount

# Iterate, checking the length of the work item number as a string.
for (
    $i = 0                 # Start at zero for first array item.
    $i -lt $fileList.Count # Stop on the last item in the array.
    $i++                   # Increment by one to step through the array.
) {
    if ($fileList[$i].Name -match $pattern) {
        $numeralCount = $Matches.WorkItemNumber.Length
        if ($numeralCount -gt $longestNumeralCount) {
            # Count is higher, check against it for remaining items.
            $longestNumeralCount = $numeralCount
            # Update the pattern to speed up the search, ignoring items
            # with a smaller numeral count using pattern matching.
            $pattern = $patternTemplate -f $longestNumeralCount
        }
    }
}

Nu u het maximumaantal cijfers voor de werkitems kent, kunt u de bestanden herhalen om ze zo nodig te hernoemen. Het volgende codefragment doorloopt de bestandslijst opnieuw, waardoor deze indien nodig worden opgeslagen. Er wordt een ander patroon voor reguliere expressies gebruikt om alleen bestanden te verwerken met een numeriek aantal dat kleiner is dan het maximum.

# Regular expression to find the numerals in the filename, but only if the
# numeral count is smaller than the longest numeral count.
$pattern = $patternTemplate -f 1, ($longestNumeralCount - 1)
for (
    $i = 0                 # Start at zero for first array item.
    $i -lt $fileList.Count # Stop on the last item in the array.
    $i++                   # Increment by one to step through the array.
) {
    # Get the file from the array to process
    $file = $fileList[$i]

    # If the file doesn't need to be renamed, continue to the next file
    if ($file.Name -notmatch $pattern) {
        continue
    }

    # Get the work item number from the regular expression, create the
    # padded string from it, and define the new filename by replacing
    # the original number string with the padded number string.
    $workItemNumber = $Matches.WorkItemNumber
    $paddedNumber   = "{0:d$longestNumeralCount}" -f $workItemNumber
    $paddedName     = $file.Name -replace $workItemNumber, $paddedNumber

    # Rename the file with the padded work item number.
    $file | Rename-Item -NewName $paddedName
}

Nu de naam van de bestanden is gewijzigd, kunt u de lijst met bestanden opnieuw ophalen en zowel de oude als de nieuwe bestanden sorteren op naam. Met het volgende codefragment worden de bestanden opnieuw opgehaald om op te slaan in een nieuwe matrix en te vergelijken met de eerste set objecten. Vervolgens worden beide matrices met bestanden gesorteerd, waarbij de gesorteerde matrices worden opgeslagen in de nieuwe variabelen $sortedOriginal en $sortedPadded. Ten slotte wordt een for lus gebruikt om de matrices te herhalen en een object met de volgende eigenschappen uit te voeren:

  • Index vertegenwoordigt de huidige index in de gesorteerde matrices.
  • Oorspronkelijk is het item in de gesorteerde matrix met oorspronkelijke bestandsnamen in de huidige index.
  • Opgevuld is het item in de gesorteerde matrix met opgevulde bestandsnamen in de huidige index.
$paddedList = Get-ChildItem -path ./work_items

# Sort both file lists by name.
$sortedOriginal = $fileList    | Sort-Object -Property Name
$sortedPadded   = $renamedList | Sort-Object -Property Name

# Iterate over the arrays and output an object to simplify comparing how
# the arrays were sorted before and after padding the work item numbers.
for (
  $i = 0
  $i -lt $fileList.Count
  $i++
) {
    [pscustomobject] @{
        Index    = $i
        Original = $sortedOriginal[$i].Name
        Padded   = $sortedPadded[$i].Name
    }
}
Index Original       Padded
----- --------       ------
    0 bug-219.json   bug-00041.json
    1 bug-41.json    bug-00219.json
    2 bug-500.json   bug-00500.json
    3 bug-697.json   bug-00697.json
    4 bug-819.json   bug-00819.json
    5 bug-840.json   bug-00840.json
    6 feat-176.json  feat-00176.json
    7 feat-367.json  feat-00367.json
    8 feat-373.json  feat-00373.json
    9 feat-434.json  feat-00434.json
   10 feat-676.json  feat-00676.json
   11 feat-690.json  feat-00690.json
   12 feat-880.json  feat-00880.json
   13 feat-944.json  feat-00944.json
   14 maint-103.json maint-00049.json
   15 maint-367.json maint-00103.json
   16 maint-454.json maint-00367.json
   17 maint-49.json  maint-00454.json
   18 maint-562.json maint-00562.json
   19 maint-579.json maint-00579.json

In de uitvoer bevinden de gesorteerde werkitems na opvulling zich in de verwachte volgorde.

Zie ook