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"