我正在编写一个脚本来获取一组组件的值,并将获取的值存储在数组中。由于有许多组件,因此我创建了一个循环,并尝试创建一个数组名称及其迭代值(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
答案 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 += ,$compip
和return ,$arr
中的前导逗号是一元数组构造运算符,可防止PowerShell展开数组。 $arr += ,$compip
将$compip
作为嵌套数组附加到$arr
(而不是将$arr
的元素附加到$compip
。 $arr
确保return ,$arr
照原样返回给调用方(因此即使该数组为空也保留该数组)。