我已经创建了下面的脚本,它接受分配给数组$PerfList的值,并使用Out显示它们。一旦选择完成,它应该将所选内容传递给$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
}
}如能提供任何帮助,将不胜感激:)
发布于 2017-06-15 09:44:57
只是为了展示压痕和保持物品整洁的重要性。
首先,$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"https://stackoverflow.com/questions/44563402
复制相似问题