我創建了下面的腳本,它將值賦給數組$ PerfList並使用Out-Gridview顯示它們。一旦選擇完成,它應該將選擇傳遞給$ Server,但不會。我得到以下錯誤:Out-Gridview不會將選擇傳遞給變量
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
}
}
任何幫助,將不勝感激:)
非常感謝你這一點,它肯定是經過選擇結束了,沒有錯誤,只是我做的事情是改變選擇採取「名稱」,而不是「 #' 但是,現在即使沒有錯誤,在選擇一個項目並按下確定後,它會顯示我選擇的內容,但不會進一步移動到腳本中。它不會在您更改的代碼 – Dax
Yeeah下執行以下步驟,因爲該值將發送到控制檯,而不是您在原始腳本中嘗試使用的$ Server變量。修改了答案。 –
我仍然是Powershell的新手(整體編碼),所以謝謝!它現在工作100% – Dax