Out-Gridview 没有将选择传递给变量
Out-Gridview not passing selection to variable
我创建了以下脚本,它获取分配给数组 $PerfList 的值并使用 Out-Gridview 显示它们。一旦做出选择,它应该将选择传递给 $Server,但没有。我收到以下错误:
Index operation failed; the array index evaluated to null. At
C:\CreateStart.ps1:7 char:21
+ foreach { $PerfList[$_.IDX] })
+ ~~~~~~~~~~~~~~~~~
+ CategoryInfo : InvalidOperation: (:) [], RuntimeException
+ FullyQualifiedErrorId : NullArrayIndex
我的代码如下:
$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" 的项目中添加 属性,它被称为“#”,因此你需要通过它来引用:
此外,语义比什么都重要,但我更喜欢 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"
我创建了以下脚本,它获取分配给数组 $PerfList 的值并使用 Out-Gridview 显示它们。一旦做出选择,它应该将选择传递给 $Server,但没有。我收到以下错误:
Index operation failed; the array index evaluated to null. At C:\CreateStart.ps1:7 char:21 + foreach { $PerfList[$_.IDX] }) + ~~~~~~~~~~~~~~~~~ + CategoryInfo : InvalidOperation: (:) [], RuntimeException + FullyQualifiedErrorId : NullArrayIndex
我的代码如下:
$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" 的项目中添加 属性,它被称为“#”,因此你需要通过它来引用:
此外,语义比什么都重要,但我更喜欢 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"