Powershell - 不允许使用空管道元素

时间:2013-10-29 07:50:21

标签: powershell csv

每当我尝试将结果输出到csv文件时,我一直收到滚动错误消息 - “不允许空管道元素”。知道为什么会这样吗?

$apps = Import-CSV apps.csv
$computers = Import-CSV compobj.csv
foreach($computer in $computers) {    
    $computerLob = $computer.lob
    $lobApps = $apps | ? {$_.lob -eq $computerLob}
    foreach($app in $lobApps){
       $appLocation = $app.location
       $installed=Test-Path "\\$computerHostname\$appLocation"
       $computerHostname = $computer.hostname     
       $results = new-object psobject -property @{Computer=$computer.hostname;App=$app.appname;Installed=$installed} | select Computer,App,Installed 
       $results 
    } 
} | Export-csv "results.csv" -NoTypeInformation

我试过这样做:

$results | Export-csv "results.csv" -NoTypeInformation
在foreach循环中

但它只返回最后一条记录。

4 个答案:

答案 0 :(得分:9)

foreach循环不会输出到管道。您可以通过使循环成为子表达式来实现:

$apps = Import-CSV apps.csv
$computers = Import-CSV compobj.csv
$(foreach($computer in $computers) {    
    $computerLob = $computer.lob
    $lobApps = $apps | ? {$_.lob -eq $computerLob}
    foreach($app in $lobApps){
       $appLocation = $app.location
       $installed=Test-Path "\\$computerHostname\$appLocation"
       $computerHostname = $computer.hostname     
       $results = new-object psobject -property @{Computer=$computer.hostname;App=$app.appname;Installed=$installed} | select Computer,App,Installed 
       $results 
    } 
}) | Export-csv "results.csv" -NoTypeInformation

答案 1 :(得分:7)

我相信你遇到的问题是使用foreach和管道,你在foreach语句中处理你的项目,但仍然期望它们在管道上。

这是一个常见错误,我在文章Essential PowerShell: Understanding foreachEssential PowerShell: Understanding foreach (Addendum)中有更详细的解释。

你应该能够达到你想要的效果:

$apps = Import-CSV apps.csv
$computers = Import-CSV compobj.csv
$computers | foreach {
    $computer = $_
    $computerLob = $computer.lob
    $lobApps = $apps | ? {$_.lob -eq $computerLob}
    $lobApps | foreach {
       $app = $_
       $appLocation = $app.location
       $installed=Test-Path "\\$computerHostname\$appLocation"
       $computerHostname = $computer.hostname     
       new-object psobject -property @{Computer=$computer.hostname;App=$app.appname;Installed=$installed} 
    } 
} | Export-csv "results.csv" -NoTypeInformation

答案 2 :(得分:1)

某些流控制表达式不流式传输其输出。 但是可以将它们分配给变量,但不能输出流。

您可以将表达式输出流放在子表达式$()中,然后使用另一个命令进行管道传输。

答案 3 :(得分:0)

您无法从任何powershell语句中进行管道传输。我不确定为什么。

if .. else
   开关
   做..而    的ForEach
   对于
   而