kromifan
Goto Top

Powershell - importierte CSV-Datei spaltenweise auslesen

Hallo zusammen,

bleibe mit meinem rudimentären Powershell-Erfahrungen an einem - wahrscheinlich kleinen - Problem hängen:


In meiner CSV-Datei gibt es mehrere Typen von "Berichten". Die vorhandenen Spalten sind alle Spalten aus allen Berichten, aber nicht jeder Bericht nutzt jede Spalte.
Bei jedem Typ soll nun ermittelt werden, ob der Bericht die Spalte jemals beschreibt oder nicht.


Meine Spalten haben Überschriften mit Umlauten und Klammern, daher lese ich die Namen mit Get-Member in eine Variable $Spalten
So weit, so gut.

Für jede Spalte möchte ich jetzt in jeder Zeile nachsehen, ob ein Wert vorhanden ist.

Dazu gibt es folgenden Loop

 ForEach ($Spalte in $Spalten){
    ForEach($Zeile in $Zeilen){
         # hier soll der Wert ermittelt werden - aber wie???
        $var = Get-Variable -Name $Spalte -ValueOnly
        $var =  $Zeile.$Spalte
        $var =  $_.$Spalte
    }
}

Keiner der Ausdrücke in der inneren Loop zeigt mir jedoch den Wert in der Spalte der entsprechenden Zeile an. Da mach ich doch was falsch! face-sad

Wie lese ich den Wert aus?

Vielen Dank für Eure Hilfe!

Content-ID: 289208

Url: https://administrator.de/contentid/289208

Ausgedruckt am: 22.11.2024 um 08:11 Uhr

122990
Lösung 122990 24.11.2015 aktualisiert um 13:25:04 Uhr
Goto Top
$csv = Import-CSV 'C:\demo.csv' -Delimiter ";"  
$spalten = $csv | gm -MemberType NoteProperty | select -Expand Name
$csv | %{
    $zeile = $_
    $spalten | %{
        $wert = $zeile.$_
        if ($wert -eq 'XYZ'){  
            write-host "Wert gefunden"  
            $zeile
        }
    }
}
Gruß grexit
Kromifan
Kromifan 24.11.2015 um 13:15:58 Uhr
Goto Top
Hm, das liefert leider auch keinen Output.

Wenn ich hinter

 $zeile = $_
        echo " wir befinden uns in $Zeile"  

und bei
$spalten | %{
                $wert = $zeile.$_
                echo "bei Wert " + $Wert  

anzeigen lasse, bekomme ich in der Zeile komplett alles richtig angezeigt, $spalten enthält auch alle Spalten, nur $wert bleibt leer, egal ob ich den Eintrag in der Zeile mit einem Wert belegt finde oder nicht. Da muss noch was Anderes seinface-sad
122990
122990 24.11.2015 aktualisiert um 13:20:49 Uhr
Goto Top
Hm, das liefert leider auch keinen Output.
Nope geht hier problemlos ...

Poste doch mal bitte deine Überschriften mit den "Sonderzeichen"

Eventuell musst du dann schreiben:
$wert = $zeile.($_)
Das $_ geht natürlich nur wenn du bei Get-Member mit Expand arbeitest wie in meinem Skript!
Kromifan
Kromifan 24.11.2015 um 13:20:27 Uhr
Goto Top
Wenn ich statt
$wert = $zeile.$_ 

einen konkreten Spaltennamen angebe wie zB:
$wert = $zeile."ID-Type"  

dann bekomme ich den korrekten Wert ausgegeben.
122990
Lösung 122990 24.11.2015 aktualisiert um 13:27:42 Uhr
Goto Top
Das $_ geht natürlich nur wenn du bei Get-Member mit Expand arbeitest wie in meinem Skript oben !!!
Ansonsten muss du in der Schleife der Spalten schreiben
$wert = $zeile.($_.Name)

Ist einfach nur ein Verständnisproblem deinerseits ... denke immer daran Objekte haben Eigenschaften wenn man sie nicht expandiert.
Kromifan
Kromifan 24.11.2015 um 13:27:43 Uhr
Goto Top
Juchuuu! Das war es, das Expand fehlte!

Danke!!!