1

我创建了下面的脚本,它获取分配给数组 $PerfList 的值并使用 Out-Gridview 显示它们。一旦做出选择,它应该将选择传递给 $Server,但不会。我收到以下错误:

索引操作失败;数组索引评估为 null。在 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
    }
}

任何帮助,将不胜感激 :)

4

1 回答 1

2

只是说明缩进和保持整洁的重要性。

首先$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"
于 2017-06-15T09:44:57.383 回答