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 Export memberof jede Gruppe in neue Zeile schreiben

Mitglied: Kangaroojack

Kangaroojack (Level 1) - Jetzt verbinden

13.06.2014, aktualisiert 17:06 Uhr, 2233 Aufrufe, 12 Kommentare

Hallo Leute,

zu Dokumentationszwecken muss ich bestimmte OU's mit Benutzerobjekten und deren Gruppenmitgliedschaften auslesen.
Mein bisheriges Arbeitsmittel der Wahl war da die Powergui. Nur leider funktioniert hier der Export von memberof nicht. Memberof wird immer nur als "System.String[]" ausgegeben

Habe etwas im Netz gestöbert und einen pasenden Powershell Code gefunden, der exportiert was ich möchte.

01.
Import-Module activedirectory 
02.
Get-QADuser -SizeLimit 0 -SearchRoot "OU=_Test;OU=Benutzer,OU=XXX,OU=XXX,OU=Kunden,DC=DOMAENE,DC=LOCAL" | Select-Object LastName,FirstName,LogonName,@{l='MemberOf'; e= { ( $_.memberof | % { (Get-ADObject $_).Name }) -join ";" }} | Sort-Object LastName | ConvertTo-Html | Set-Content "HtmlReport.html"
Das Ergebnis sieht dann wie folgt aus

b680cbbe640c7ea152dd9a270d28874d - Klicke auf das Bild, um es zu vergrößern


Ich möchte allerdings, wegen besserer Übersichtlichkeit, dass die Gruppen für den Benutzer nicht hintereinandergereiht werden, sondern jede Gruppe in eine neue Zeilge geschrieben wird, also so:

d8cd6abbf0281679e263c2037a5b7dd8 - Klicke auf das Bild, um es zu vergrößern

Leider fehlen mir zur Umsetzung die nötigen Skriptkentnisse. Würde mich freuen wenn mir hier jemand weiterhelfen könnte!
Im Voraus, vielen Dank!

LG
KangarooJack
Mitglied: colinardo
13.06.2014, aktualisiert um 11:27 Uhr
Moin KangarooJack,
(nur eine minimale Änderung im -join nötig: das Semikolon ersetzt durch einen Zeilenumbruch `r`n)
01.
Import-Module activedirectory 
02.
Get-QADuser -SizeLimit 0 -SearchRoot "OU=_Test;OU=Benutzer,OU=XXX,OU=XXX,OU=Kunden,DC=DOMAENE,DC=LOCAL" | Select-Object LastName,FirstName,LogonName,@{l='MemberOf'; e= { ( $_.memberof | % { (Get-ADObject $_).Name }) -join "`r`n" }} | Sort-Object LastName | ConvertTo-Html | Set-Content "HtmlReport.html"
Grüße Uwe
Bitte warten ..
Mitglied: Kangaroojack
13.06.2014 um 11:41 Uhr
Hallo Uwe,

danke für deinen Beitrag, das hatte ich bereits schon probiert, führt aber nicht zum Erfolg.
Die Ausgabe bleibt weiterhin wie in Bild 1 zu sehen, leider...
Bitte warten ..
Mitglied: colinardo
13.06.2014, aktualisiert um 11:55 Uhr
Ah OK sehe das Problem, mit einem eingefügten ft -AutoSize -Wrap sollte es jetzt wie gewünscht aussehen:
01.
Import-Module activedirectory 
02.
Get-QADuser -SizeLimit 0 -SearchRoot "OU=_Test;OU=Benutzer,OU=XXX,OU=XXX,OU=Kunden,DC=DOMAENE,DC=LOCAL" | Select-Object LastName,FirstName,LogonName,@{l='MemberOf'; e= { ( $_.memberof | % { (Get-ADObject $_).Name }) -join "`r`n" }} | Sort-Object LastName | ft -AutoSize -Wrap | ConvertTo-Html | Set-Content "HtmlReport.html"
Bitte warten ..
Mitglied: Kangaroojack
13.06.2014, aktualisiert um 12:05 Uhr
Hallo nochmal,

auf der Shell Ebene sieht die Ausgabe nun wirklich wie gewünscht aus - leider zerlegt es den HTML Export aber total

c4de6be697de8e5a0cc42615c5009018 - Klicke auf das Bild, um es zu vergrößern
Bitte warten ..
Mitglied: colinardo
13.06.2014, aktualisiert um 15:40 Uhr
dann mach es mit mehr Kontrolle über den Output so:
(convertto-html ist in dieser Hinsicht nicht sehr flexibel was die Formatierung in den Zellen angeht, im Gegensatz zum Export in eine Textdatei, dort wird die Formatierung beibehalten)
01.
$users = Get-QADuser -SizeLimit 0 -SearchRoot "OU=_Test,OU=Benutzer,OU=XXX,OU=XXX,OU=Kunden,DC=DOMAENE,DC=LOCAL" | Select-Object LastName,FirstName,LogonName,@{l='MemberOf'; e= { ( $_.memberof | % { (Get-ADObject $_).Name })}} | Sort-Object LastName 
02.
 
03.
$users | %{$rows += "<tr><td>$($_.LastName)</td><td>$($_.Firstname)</td><td>$($_.LogonName)</td><td>$($_.MemberOf -join "<br/>")</td></tr>"} 
04.
 
05.
$html = @" 
06.
<!DOCTYPE HTML> 
07.
<html> 
08.
<head> 
09.
	<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
10.
	<title>HTML Dokument</title> 
11.
</head> 
12.
<style> 
13.
table{ 
14.
  border-spacing: 0; 
15.
  border-collapse: collapse; 
16.
17.
td,th { 
18.
 vertical-align: top; 
19.
 border:1px solid gray; 
20.
 padding: 5px; 
21.
22.
th{ 
23.
 font-weight: bold; 
24.
 font-size: 13pt; 
25.
 text-align: left; 
26.
27.
</style> 
28.
<body>        
29.
<table> 
30.
<tr><th>LastName</th><th>FirstName</th><th>LogonName</th><th>memberOf</th></tr> 
31.
$rows 
32.
<table>            
33.
</body>  
34.
</html> 
35.
"@ 
36.
 
37.
$html | set-content "HtmlReport.html"
Grüße Uwe
Bitte warten ..
Mitglied: Kangaroojack
13.06.2014 um 15:24 Uhr
Leider funktioniert auch das nicht wie es soll

- die erste Spalte wird immer mit dem Vornamen gefüllt
habe schon $_.LastName mit $_.FirstName getauscht, das bringt aber nix

- irgendwie verhagelt es den Familiennamen teilweise total:
$ @{LastName=XXX; FirstName=XXX; LogonName=XXX; MemberOf=System.Object[]}.FirstName)

- wenn ich mit -SearchScope OneLevel das ganze auf die eine OU begrenzen will interessiert ihn das auch nicht


Ahhhh zum Wahnsinnig werden!
Bitte warten ..
Mitglied: colinardo
13.06.2014, aktualisiert um 15:44 Uhr
dann machst du grundsätzlich was falsch, geht hier testweise einwandfrei...aber getestet mit get-aduser anstatt get-qaduser was man eigentlich nicht braucht wenn man weiß wie man dort an die erweiterten Eigenschaften kommt !

Wenn du eine Variable deren Eigenschaften du ansprichst innerhalb eines Strings einbaust musst du ein $() um das Konstrukt bauen also dann z.B. so $($_.Lastname) , ansonsten wird dir eine Hashtable des Objekts mit allen Eigenschaften ausgegeben !
Bitte warten ..
Mitglied: Kangaroojack
13.06.2014, aktualisiert um 16:39 Uhr
- irgendwie verhagelt es den Familiennamen teilweise total:
$ @{LastName=XXX; FirstName=XXX; LogonName=XXX; MemberOf=System.Object[]}.FirstName)

=> das ist behoben, war ein Leerzeichen drin

dennoch stimmt die html Ausgabe nicht. Last und Firstname sind vertauscht.

anbei nochmal der code

01.
Import-Module activedirectory 
02.
$users = Get-QADuser -SizeLimit 50 -SearchRoot "OU=Benutzer,OU=XXX,OU=XXX,OU=XXX,DC=DOMAENE,DC=LOCAL" -SearchScope OneLevel | Select-Object LastName,FirstName,LogonName,@{l='MemberOf'; e= { ( $_.memberof | % { (Get-ADObject $_).Name })}} 
03.
 
04.
$users | %{$rows += "<tr><td>$($_.LastName)</td><td>$($_.FirstName)</td><td>$($_.LogonName)</td><td>$($_.MemberOf -join "<br/>")</td></tr>"} 
05.
 
06.
$html = @" 
07.
<!DOCTYPE HTML> 
08.
<html> 
09.
<head> 
10.
	<meta http-equiv="Content-Type" content="text/html; charset=utf-32"> 
11.
	<title>HTML Dokument</title> 
12.
</head> 
13.
<style> 
14.
table{ 
15.
  border-spacing: 0; 
16.
  border-collapse: collapse; 
17.
18.
td,th { 
19.
 vertical-align: top; 
20.
 border:1px solid gray; 
21.
 padding: 5px; 
22.
23.
th{ 
24.
 font-weight: bold; 
25.
 font-size: 13pt; 
26.
 text-align: left; 
27.
28.
</style> 
29.
<body>        
30.
<table> 
31.
<tr><th>LastName</th><th>FirstName</th><th>LogonName</th><th>memberOf</th></tr> 
32.
$rows 
33.
<table>            
34.
</body>  
35.
</html> 
36.
"@ 
37.
 
38.
$html | set-content "HtmlReport.html"


Führe ich
01.
Get-QADuser -SizeLimit 50 -SearchRoot "OU=Benutzer,OU=XXX,OU=XXX,OU=XXX,DC=DOMAENE,DC=LOCAL" -SearchScope OneLevel | Select-Object LastName,FirstName,LogonName,@{l='MemberOf'; e= { ( $_.memberof | % { (Get-ADObject $_).Name })}}
aus, werden die Benutzerdaten aber richtig sortiert ausgegeben, d.h. LastName, FirstName,LogonName,MemberOf
Bitte warten ..
Mitglied: colinardo
LÖSUNG 13.06.2014, aktualisiert um 17:06 Uhr
dann muss das an Get-QADUser liegen hier geht es mit Get-AdUser so einwandfrei !
01.
$users = Get-ADUser -Filter * -Properties * -SearchBase "OU=Benutzer,OU=XXX,OU=XXX,OU=XXX,DC=DOMAENE,DC=LOCAL" -SearchScope OneLevel -ResultSetSize 50 | select surname,Givenname,SamAccountName,@{name='MemberOf2';e={($_.memberof | %{(Get-ADObject $_).Name})}} 
02.
 
03.
$users | %{$rows += "<tr><td>$($_.surname)</td><td>$($_.Givenname)</td><td>$($_.SamAccountName)</td><td>$($_.MemberOf2 -join "<br/>")</td></tr>"} 
04.
 
05.
$html = @" 
06.
<!DOCTYPE HTML> 
07.
<html> 
08.
<head> 
09.
	<meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 
10.
	<title>HTML Dokument</title> 
11.
</head> 
12.
<style> 
13.
table{ 
14.
  border-spacing: 0; 
15.
  border-collapse: collapse; 
16.
17.
td,th { 
18.
 vertical-align: top; 
19.
 border:1px solid gray; 
20.
 padding: 5px; 
21.
22.
th{ 
23.
 font-weight: bold; 
24.
 font-size: 13pt; 
25.
 text-align: left; 
26.
27.
</style>                                          
28.
<body>        
29.
<table> 
30.
<tr><th>LastName</th><th>Firstname</th><th>Logonname</th><th>memberOf</th></tr> 
31.
$rows 
32.
<table>            
33.
</body>  
34.
</html> 
35.
"@ 
36.
 
37.
$html | out-File "HtmlReport.html"
659bec8e882f0ed3b5886b37cb7f6437 - Klicke auf das Bild, um es zu vergrößern
Bitte warten ..
Mitglied: Kangaroojack
13.06.2014, aktualisiert um 16:56 Uhr
es gibt für Get-ADUser kein -SearchRoot - dementsprechend geht dein geposteter Code leider nicht - oder ich bin total daneben heute ;)
Bitte warten ..
Mitglied: colinardo
13.06.2014, aktualisiert um 17:00 Uhr
sorry, das hatte ich von dir übernommen, es muss natürlich -SearchBase lauten. Aber einfach auf der Konsole nachgeschaut hättest du es auch gefunden ...
Bitte warten ..
Mitglied: Kangaroojack
13.06.2014 um 17:06 Uhr
Sorry, natürlich hätte ich da schon drauf kommen können - bin nur mittlerweile etwas ausgelaugt, schaue schon den ganzen Tag auf den blöden Code und hab 1000 Fenster auf ;)

Jetzt funktioniert es auch wie gewünscht!
Vielen herzlichen Dank!!!!!!!!!!!!!!
Bitte warten ..
Ähnliche Inhalte
Batch & Shell
Powershell export
gelöst Frage von SquenterBatch & Shell5 Kommentare

Hallo, ich muss aus Active Directory eine Liste exportieren, von Usern die eine Telefonnummer haben! Leider exportiert mein Skript ...

Windows Systemdateien

Zwei Befehle in eine Zeile schreiben in Powershell bzw cmd

gelöst Frage von VidcrafterWindows Systemdateien4 Kommentare

Hallo, ich wollte Zwei Befehle hintereinander in Powershell in eine Zeile schreiben, doch leider fehlt mir der passende Pa­ra­me­ter. ...

Batch & Shell

Bestimmte Zeile aus mehreren Dateien in eine neue Datei schreiben

gelöst Frage von Oggy76Batch & Shell5 Kommentare

Hallo zusammen, meine Kenntnisse in Sachen batch/shell sind ehr auf Anfängerniveau zu sehen. Grund -basics im CMD-Prompt sind vorhanden, ...

Batch & Shell

Powershell - HL7 - Export nach CSV

gelöst Frage von internet2107Batch & Shell1 Kommentar

Folgendes Problem. Es geht um das Einlesen einer HL7 Datei, die zu einer CSV-Datei exportiert/umgewandelt werden soll. Die einzulesende ...

Neue Wissensbeiträge
Humor (lol)
IoT-Gefahr: Smartes Aquarium leckt!
Information von Lochkartenstanzer vor 1 TagHumor (lol)3 Kommentare

Moin, Die IoT-Manie hat weitere Opfer gefunden. Ein Casino-Leck durch ein smartes Aquarium: Allerdings haben sie kein Wasser, sondern ...

Router & Routing

Alte Fritzbox 7270 mit VPN und SIP-Telefonie hinter O2 Homebox 6641 als "Modem"

Erfahrungsbericht von the-buccaneer vor 1 TagRouter & Routing3 Kommentare

Nun war es soweit: Auch O2 hat mich mit VOIP zwangsbeglückt. Heute am Privatanschluss, in 2 Wochen ist das ...

Sicherheit

Ungepatchte Remote Code Execution-Lücke in LG NAS

Information von kgborn vor 2 TagenSicherheit

Nutzt wer LG NAS-Einheiten? In den NAS-Einheiten der LG Network Storage-Einheiten gibt es eine sehr unschöne Schwachstelle, die einen ...

Windows Update

Neue Version KB4099950 NIC Einstellungen gehen verloren

Information von sabines vor 2 TagenWindows Update2 Kommentare

Es ist eine neue Version des KB4099950 verfügbar, die das Problem mit den verlorenen Netzwerkeinstellungen lösen soll. Das Datum ...

Heiß diskutierte Inhalte
Sicherheit
Verbindliche Zustellung per E-Mail?
Frage von ahussainSicherheit18 Kommentare

Hallo allerseits, ein Kunde von mir nutzt intensiv Fax. Hauptgrund: zusammen mit einer Empfangsbestätigung ist eine verbindliche Zustellung gewährleistet. ...

Router & Routing
Mikrotik: Routing zwischen Interfaces mit Geräten ohne Gateway
Frage von TonLichtVideoRouter & Routing18 Kommentare

Hallo zusammen, ich komme aus dem Veranstaltungstechnik Bereich und habe zwei Netze um verschiedene Hardware zu Remoten. CONTROL1 192.168.1.0/24 ...

Linux Netzwerk
Raspberry Pi 3: WLAN Power save deaktivieren
Frage von nordie92Linux Netzwerk14 Kommentare

Moin moin, mein Raspberry Pi 3 Model B benötigt eine dauerhaft aktive WLAN-Verbindung. Leider bricht die WLAN-Verbindung nach einigen ...

SAN, NAS, DAS
Entscheidung SAN Dell oder HP
Frage von VincorSAN, NAS, DAS13 Kommentare

Hallo, wir wollen uns für unsere Hyper V Umgebung eine neue SAN Anschaffen. Es laufen 30 VM's darunter, DC; ...