如何在Powershell的循环内创建一堆数组

时间:2018-12-05 12:28:32

标签: arrays excel for-loop arraylist powershell-v4.0

我正在编写一个脚本来获取一组组件的值,并将获取的值存储在数组中。由于有许多组件,因此我创建了一个循环,并尝试创建一个数组名称及其迭代值(fi1,fi2,fi3等),如下所示。

代码如下:

function fiswitchinfo {
    Param ($sheet, [string]$text, $iter)

    $($fi+($iter)) = @()
    $max = $sheet.UsedRange.Rows.Count
    for ($i=1; $i -lt 900 ; $i++) {
        $rows = $sheet.Cells.Item($i, 2).EntireRow
        $cell_info = $sheet.Cells.Item($i, 2)
        $cell = $cell_info.Address($false, $false)
        if ($rows.hidden -eq $false) {
            $cell_info = $sheet.Cells.Item($i, 2).Text

            if ($cell_info -ne "" -and $cell_info.Contains($text) -eq "True") {
                $cell = $cell -split "(?<=[A-Z])(?=\d)"
                [int]$curline =  $cell[1]
                $component = $sheet.Cells.Item($curline, 2).Text
                $compip = $sheet.Cells.Item($curline, 3).Text

                $row = $sheet.Cells.Item($curline, 2).EntireRow
                $cellinfo = $sheet.Cells.Item($curline, 2).text
                if ($row.Hidden -ne "True" -and $cellinfo -ne $null) {
                    Write-Host $component $compip
                    $script:fi+$iter += $compip
                }
            }
        }
    }
}

fiswitchinfo $worksheet_3 "Fabric Interconnect 01 Cluster IP" 1
fiswitchinfo $worksheet_3 "Fabric Interconnect 01 A" 1
fiswitchinfo $worksheet_3 "Fabric Interconnect 01 B" 1

1 个答案:

答案 0 :(得分:0)

我不太确定您期望$($fi+($iter))$script:fi+$iter会做什么,但是我很确定他们不会按照您的期望去做。

要让一个函数在循环中创建一个数组数组,然后返回它,您可以执行以下操作:

function fiswitchinfo {
    ...
    $arr = @()
    for ($i=1; $i -lt 900 ; $i++) {
        ...
        $arr += ,$compip
    }
    return ,$arr
}

$fi1 = fiswitchinfo ...
$fi2 = fiswitchinfo ...
...

语句$arr += ,$compipreturn ,$arr中的前导逗号是一元数组构造运算符,可防止PowerShell展开数组。 $arr += ,$compip$compip作为嵌套数组附加到$arr(而不是将$arr的元素附加到$compip$arr确保return ,$arr照原样返回给调用方(因此即使该数组为空也保留该数组)。