Out-Gridview не передает выделение переменной

Я создал приведенный ниже скрипт, который принимает значения, присвоенные массиву $PerfList, и отображает их, используя Out-Gridview. Как только выбор сделан, он должен передать выбор в $Server, но это не так. Я получаю следующую ошибку:

Сбой операции индексации; индекс массива оценивается как ноль. В 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
    }
}

Любая помощь будет оценена:)

1 ответ

Решение

Просто показывает важность отступов и аккуратности.

Прежде всего $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"
Другие вопросы по тегам