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
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
Bitte markiere auch die Kommentare, die zur Lösung des Beitrags beigetragen haben
Content-ID: 180510
Url: https://administrator.de/contentid/180510
Ausgedruckt am: 05.11.2024 um 12:11 Uhr
1 Kommentar
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)
]
happy testing
Karo
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