ralfkausk
Goto Top

Powershell for-schleife

Ich brauche hilfe mit der Powershell ...

Ich möchte folgendes machen
Ich habe eine Liste mit Benutzkonten.
Diese möchte ich mit einem script überprüfen um zu sehen ob alle konten noch aktiv sind, oder ob einige evtl. schon gelöscht oder auf inaktive gesetzt wurden.

Dazu benutze ich den Befehl:
net user %Benutzkonto% /domain | grep -i "aktiv"
(ich habe diverse UNIX Freeware Tolls im System, darum benutze ich den grep Befehl)

Alternativ ginge auch:
net user %Benutzkonto% /domain | find /I "aktiv"

Da ich etwas mehr als 1400 IDs überprüfen muss möchte ich das in einer Schleife machen.

Von UNIX Seite kenne ich folgendes

for ID in `cat liste.txt`;do
VAR1='net user $ID /domain | grep -i "aktiv'
echo $ID - $VAR1
done


Gibt es was vergleichbares mit der Powershell?
Ich hatte schon mal gestöber und hab auch ein paar sachen gefunden, nur nicht genau das was ich brauche.
Und da ich totaler noob bin mit der Powershell hoffe ich das mir hier jemand auf die Sprünge helfen kann

$Users = get-content "liste.txt"
foreach ($User in $Users)
{
$ACTIVESTATE = net user $User /domain | grep -i "active"
write $User:$ACTIVESTATE "ausgabe.txt"
}


Die Ausgabe am Ende soll eigentlich folgendermaßen aussehen:
Benutzername; active yes
oder
Benutzername: error, user does not exist

Ich bin auch für ander Ansätze zu haben, es muß nicht zwangläufig mit dem net Befehl gemacht werden.
Allerdings muß ich dazu sagen, das ich zwar in gewissen Umfang Adminrechte habe, aber eben nicht auf dem Server.

Vielen dank schon mal im voraus
Ralf

Content-ID: 180510

Url: https://administrator.de/forum/powershell-for-schleife-180510.html

Ausgedruckt am: 23.12.2024 um 04:12 Uhr

Karo
Karo 14.02.2012 um 15:13:55 Uhr
Goto Top
Hoi,

hier eine Vorlage. brauchst Du eigentlich nur abändern
[ Beispiel welche Zeilen angepasst werden
$objSearcher.PropertiesToLoad.AddRange(@("name"))
und korrespondierend
$temp | Add-Member NoteProperty name $($objitem.name)
]

Cls
$strFilter = "(&(objectCategory=User))"  
$objDomain = New-Object System.DirectoryServices.DirectoryEntry
$objSearcher = New-Object System.DirectoryServices.DirectorySearcher
$objSearcher.SearchRoot = $objDomain
$objSearcher.PageSize = 1000
$objSearcher.Filter = $strFilter
$objSearcher.SearchScope = "Subtree"  

$objSearcher.PropertiesToLoad.AddRange(@("name"))  
$objSearcher.PropertiesToLoad.AddRange(@("lastLogon"))  
$objSearcher.PropertiesToLoad.AddRange(@("givenName"))  
$objSearcher.PropertiesToLoad.AddRange(@("SN"))  
$objSearcher.PropertiesToLoad.AddRange(@("DisplayName"))  
$objSearcher.PropertiesToLoad.AddRange(@("title"))  
$objSearcher.PropertiesToLoad.AddRange(@("mail"))  
$objSearcher.Container

$users = $objSearcher.findall()
$users.Count
$report = @()

foreach ($objResult in $users)
{
$objItem = $objResult.Properties
$temp = New-Object PSObject
$temp | Add-Member NoteProperty name $($objitem.name)
$temp | Add-Member NoteProperty title $($objitem.title)
$temp | Add-Member NoteProperty mail $($objitem.mail)
$temp | Add-Member NoteProperty displayname $($objitem.displayname)
$temp | Add-Member NoteProperty givenname $($objitem.givenname)
$temp | Add-Member NoteProperty sn $($objitem.sn)
$temp | Add-Member NoteProperty useraccountcontrol $($objitem.useraccountcontrol)
$report += $temp
}

$csvfile="AD-EXPORT".csv"  
$report | export-csv -notypeinformation $csvfile
"Wrote file $csvfile"  

happy testing

Karo