2017-05-04 3 views
1

Hilfe zum Erstellen eines Skripts zum Abrufen eines HPOA-Server-Blade Integritätsbericht Das Problem ist, dass wenn ich abfragen Gesundheit in einem PSO-Objekt mit Feldern (IP, Health, Blades (@ {Blade1 ... Gesundheit} {Blade2 Gesundheit} {3})) ich möchte einen Bericht wie untenExcel-Bericht Formatierung in PowerShell

IP Bay Power Health
- --- ----- -----
10.3. 131.2 1 ein OK
2 ein OK
3 ein OK
4 Ein OK
5 On Degraded

Die Variablen werden wie folgt abgeleitet.

$ sstaInfo = {} | Wählen Sie IP, Bay, Power, Health und DeviceFailure aus.
$ sstaInfo.IP = $ ssta.IP (Gibt eine einzige IP-Ausgabe) $ sstaInfo.Bay = $ sstaBlades.Bay $ sstaInfo.Power = $ sstaBlades.Power $ sstaInfo .Health = $ sstaBlades.Health

Wie kann ich das funktionieren?

$ ssta Variable hat die folgende Ausgabe: @ {Power = On; CurrentWattageUsed = 480; Gesundheit = OK; UnitIdentificationLED = Aus; VirtualFan = 33%; DiagnosticStatus =; Schacht = 1} @ {Leistung = Ein; CurrentWattageUsed = 576; Gesundheit = OK; UnitIdentificationLED = Aus; VirtualFan = 47%; DiagnosticStatus =; Bay = 2}

#------------------------------------------------------------ Input Variable Definations 

$HPOAServers [email protected](
[pscustomobject]@{Name='10.11.12.13'}, 
[pscustomobject]@{Name='10.11.12.14'} 
) 

$Username ="admin" 
$Password ="admin" 

#------------------------------------------------------------ Main Script Starts Here 

# Function for connecting to OA and returning connection object on success 




foreach ($HPOAServer in $HPOAServers) { 

$con = Connect-HPOA $HPOAServer.Name -username $Username -password $Password 

$report = @() 

$ssta = Get-HPOAServerStatus -Bay All $con 

       $sstaBlade=$ssta.Blade 
       Write-Host $sstaBlade 
       Foreach ($sstaBlades in $sstaBlade) { 
        $i++ 

        $sstaInfo = {} | Select IP, Bay, Power, Health, DeviceFailure     
        $sstaInfo.IP=$ssta.IP 
        $sstaInfo.Bay=$sstaBlades.Bay 
        $sstaInfo.Power=$sstaBlades.Power 
        $sstaInfo.Health=$sstaBlades.Health 
$sstaInfo.DeviceFailure=$ssta.Blade.DiagnosticStatus.DeviceFailure 


       } 




$report += $ssta | Select-Object -Property IP 
$report += $ssta.Blade | Select-Object -Property Bay, Power, Health | Format-Table *       
$report | out-file "HPOA_Health_Report.txt" -Append   

} 
Disconnect-HPOA $con 

Antwort

0
Function HPOA() { 
try 
{ 
     Remove-Item -Path $outputfile -Force 
     foreach ($HPOAServer in $HPOAServers) 
     { 
      $con = Connect-HPOA $HPOAServer.Name -username $Username -password $Password -ErrorAction 'Stop' 
      $ssta = Get-HPOAServerStatus -Bay All $con 

     $ssta.Blade | Foreach-Object { 
     $sstaInfo = $_ 

     $sstaInfo | Select-Object -Property @{Name="Chassis_IP_Address";Expression={$ssta.IP}}, 
      @{Name="Blade_Power_Status";Expression={$_.Power}}, 
      @{Name="Blade_Bay_Number";Expression={$_.Bay}}, 
      @{Name="Blade_Health_Status";Expression={$_.Health}}, 
      @{Name="Blade_Diagnostic_DeviceFailure_Status";Expression={$ssta.Blade.DiagnosticStatus.DeviceFailure}} 

     } | ConvertTo-Html -Title " $HPOARegionName HPOA Health Report " -Head $Header -Body "<H2> $HPOARegionName HPOA Health Report </H2>" -As Table | Out-File -Append $outputfile 
     Disconnect-HPOA $con 
    } 


} 

catch 
{ 
    $ErrorMessage = $_.Exception.Message 
    $FailedItem = $_.Exception.ItemName 
    Write-Host $ErrorMessage 
    Write-Host $FailedItem 

} 

} 

HPOA 
+0

Das obige funktionierte wie ein Charme für mich :) –

1

Ich schlage vor, Sie Export-CSV verwenden stattdessen so unterhalb der Linie

$report | Out-File "HPOA_Health_Report.txt" -Append 

wird ersetzt durch:

$report | Export-Csv "HPOA_Health_Report.csv" -Append -NoTypeInformation 
+0

Dies funktioniert nicht, gibt eine leere Ausgabe –