Top-Themen

Aktuelle Themen (A bis Z)

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit
GELÖST

Powershell Where-Object Bedingungen

Frage Entwicklung Batch & Shell

Mitglied: derhoeppi

derhoeppi (Level 2) - Jetzt verbinden

08.07.2013 um 10:23 Uhr, 3327 Aufrufe, 3 Kommentare

Hallo Leute,

ich importiere eine CSV Datei in einem Powershell Skript. Die CSV Datei enthält Informationen zu Virtuellen Maschinen (PowerStatus, OS, Name der VM, VM-ID, etc.). Beim Import der CSV soll nach bestimmten Werten gefiltert werden.Ich möchte die CSV Datei nach dem PowerStatus filtern, möchte aber bestimmte Virtuelle Maschinen ausfiltern.
Die virtuellen Maschinen die ich ausfilter schreibe ich in eine Variable / Konstante.

$FilterOut = "VM1","VM2"

Danach verwende ich zum Filtern zwei Mal Where-Object. Einmal für den PowerStatus und einmal für das Ausfiltern der VM's in der Variablen. Mein Problem besteht nun darin das mein Skript nur funktioniert, wenn in der Variablen / Konstanten nur ein VM Name steht. Sobald zwei VM Namen in der Varaiblen sind, wird die Bedingungn übergangen. Kann ich meine Anforderung überhaupt über eine Variable lösen?

Where-Object -FilterScript {$_.VMName -ne $FilterOut}




Mitglied: colinardo
08.07.2013, aktualisiert um 20:38 Uhr
Hi derhoeppi,
du kannst die Maschinen die ausgefiltert werden sollen in ein Powershell Array schreiben und dann z.B. mit einer inneren Schleife die das Array durchgeht ausfiltern:
01.
$csv = Import-Csv  -Path "C:\deine.csv" 
02.
$FilterOut = @("VM1","VM2") 
03.
$filteredObject = @() 
04.
foreach ($vm in $csv){ 
05.
    $filterMachine = $false 
06.
    foreach($n in $FilterOut){ 
07.
        if($vm.Name -eq $n){ 
08.
            $filterMachine = $true 
09.
        }    
10.
11.
    if (!$filterMachine){ 
12.
        $filteredObject += $vm 
13.
14.
15.
$filteredObject
$filteredObject ist dabei ein Objekt ohne die gefilterten Maschinen.

Grüße Uwe
Bitte warten ..
Mitglied: colinardo
08.07.2013, aktualisiert um 20:59 Uhr
Fält mir gerade ein, geht auch einfacher:
01.
$csv = Import-Csv -Path "C:\DEINECSV.csv" 
02.
$FilterOut = @("VM1","VM2") 
03.
$csv | ?{$FilterOut -notcontains $_.Name}
Beachte dabei folgendes:
-notcontains ist nicht case sensitive. Wenn du möchtest das Groß- und Kleinschreibung beachtet werden sollen musst du -cnotcontains verwenden.

wenn du jetzt noch die Powerstatus-Bedingung mit in das Where-Object reinpacken willst schreib die obige Zeile z.B. so
$csv | ?{$FilterOut -notcontains $_.Name -and $_.PowerStatus -eq "ON"}
Uwe
Bitte warten ..
Mitglied: derhoeppi
09.07.2013 um 07:41 Uhr
Hallo colinardo,

vielen Dank für deine Hilfe. Nun hat das Skript auch noch seine letzte Anforderung erfüllt.

Gruß
derhoeppi
Bitte warten ..
Ähnliche Inhalte
Batch & Shell
PowerShell Where-Object multiple Conditions
gelöst Frage von derhoeppiBatch & Shell2 Kommentare

Hallo, ich habe ein Array das mit Where-Object gefiltert wird. Beim Aufbau des Filters stehe ich jedoch vor einem ...

Datenbanken
SQL max wert in WHERE Bedingung
gelöst Frage von StarMannDatenbanken7 Kommentare

Hi, ich möchte alle Daten Sätze aus dem größten Jahr, Wie bekomme ich den wert in die WHERE Bedingung? ...

Batch & Shell
PowerShell Transpose Objects und Memoryleak
gelöst Frage von agowa338Batch & Shell11 Kommentare

Hallo, weiß jemand wie ich folgenden Powershell Code etwas optimieren kann? Ich habe sehr viele Eventlog Einträge 100.000 die ...

Batch & Shell
PowerShell Compare-Object
gelöst Frage von derhoeppiBatch & Shell1 Kommentar

Hallo mit Hilfe von Compare-Object vergleiche ich zwei Array. Dabei kommen einige Unterschiede heraus. Ich habe ein führendes Array ...

Neue Wissensbeiträge
Viren und Trojaner

Deaktivierter Keylogger in HP Notebooks entdeckt

Information von bitcoin vor 16 StundenViren und Trojaner1 Kommentar

Ein Grund mehr warum man Vorinstallationen der Hersteller immer blank bügeln sollte Der deaktivierte Keylogger findet sich im vorinstallierten ...

Router & Routing

Lets Encrypt kommt auf die FritzBox

Information von bitcoin vor 19 StundenRouter & Routing

In der neuesten Labor-Version der FB7490 integriert AVM unter anderem einen Let's Encrypt Client für Zugriffe auf das Webinterface ...

Internet

Was nützt HTTPS, wenn es auch von Phishing Web-Seiten genutzt wird

Information von Penny.Cilin vor 3 TagenInternet17 Kommentare

HTTPS richtig einschätzen Ob man eine Webseite via HTTPS aufruft, zeigt ein Schloss neben der Adresse im Webbrowser an. ...

Webbrowser

Bugfix für Firefox Quantum released - Installation erfolgt teilweise nicht automatisch!

Erfahrungsbericht von Volchy vor 4 TagenWebbrowser8 Kommentare

Hallo zusammen, gem. dem Artike von heise online wurde mit VersionFirefox 57.0.1 sicherheitsrelevante Bugs behoben. Entgegen der aktuellen Veröffentlichung ...

Heiß diskutierte Inhalte
Batch & Shell
Trusted Sites für alle User auf dem PC einpflegen
Frage von xXTaKuZaXxBatch & Shell12 Kommentare

Aufgabestellung: Es sollen auf 1 PC (bzw. mehreren PCs) vertrauenswürdige Sites per Powershell eingetragen werden, die für alle User ...

Voice over IP
Telefonstörung - Ortsrufnummern kein Verbindungsaufbau
Frage von Windows10GegnerVoice over IP10 Kommentare

Hallo, sowohl bei uns als auch beim Opa ist es über VoIP nicht möglich Ortsrufnummern anzurufen. Es kommt nach ...

Vmware
DOS 6.22 in VMWare mit CD-ROM
gelöst Frage von hesperVmware10 Kommentare

Hallo zusammen! Ich hab ein saublödes Problem. Es ist eine VMWare mit DOS 6.22 zu erstellen auf dem ein ...

Cloud-Dienste
PIM als SaaS Nutzungsgebühr
Frage von vanTastCloud-Dienste8 Kommentare

Moin, wir haben uns ein PIM (Product Information Management) nach unseren Ansprüchen für viel Geld als SaaS-Lösung bauen lassen. ...