我创建了以下脚本,该脚本将分配给数组的值$PerfList并使用Out-Gridview显示它们。选择完成后,它应该将选择传递给$Server,但不会。我收到以下错误:
索引操作失败;数组索引的计算结果为 null。在 C:\CreateStart.ps1:7 字符:21 + foreach { $PerfList[$_.IDX] }( + ~~~~~~~~~~~~~~~~~ + 类别信息 : 无效操作: (:)[], 运行时异常 + 完全限定错误 ID : 空数组索引
我的代码如下:
$PerfList = @("Primary", "SQL", "APE", "Netflow", "AWE")
$IDX = 0
$Server = ($(foreach ($item in $PerfList){
$item | select @{l='#';e={$IDX}},@{l='Name';e={$PerfList[$IDX]}}
$IDX++}) |
Out-Gridview -Title 'What server is this?' -OutputMode Single |
foreach { $PerfList[$_.IDX] })
$TaskName = Switch ($Server)
{
'Primary' {'SolarWinds_App'}
'SQL' {'SolarWinds_SQL'}
'APE' {'SolarWinds_APE'}
'Netflow' {'SolarWinds_Netflow'}
'AWE' {'SolarWinds_AWE'}
}
Switch ($Server) {
'Primary' {
logman import $TaskName -xml "Primary.xml" -y
logman start $TaskName
}
'SQL' {
logman import $TaskName -xml "SQL.xml" -y
logman start $TaskName
}
'APE' {
logman import $TaskName -xml "APE.xml" -y
logman start $TaskName
}
'Netflow' {
logman import $TaskName -xml "Netflow.xml" -y
logman start $TaskName
}
'AWE' {
logman import $TaskName -xml "AWE.xml" -y
logman start $TaskName
}
}
任何帮助将不胜感激:)
只是为了显示缩进和保持整洁的重要性。
首先,$IDX++
在您的 Select 语句中,所以这应该是错误的。
其次,你不能从Foreach (x in y) { }
语句中管道。
第三,您没有将名为"IDE"的属性添加到名为"IDE"的项中,它称为"#",因此您需要引用:
此外,语义比任何东西都多,但我更喜欢从对象获取特定属性时Select
。
这应该可以解决问题:
$PerfList = @("Primary", "SQL", "APE", "Netflow", "AWE")
$IDX = 0
$Server = foreach ($item in $PerfList)
{
$item | select @{ l='#';e={ $IDX } },@{ l='Name';e={ $PerfList[$IDX] } }
$IDX++
}
$Server = $Server | Out-Gridview -Title 'What server is this?' -OutputMode Single |
Select -ExpandProperty "Name"