Как я могу отформатировать CSV для этого скрипта? - PullRequest
0 голосов
/ 15 ноября 2018

У меня есть скрипт, который сканирует все серверы в AD и возвращает членов локальной группы.Можете ли вы помочь мне обновить скрипт так, чтобы выходной формат был сгруппирован по серверам с заголовком - Имя сервера, Имя локальной группы, Члены, Тип?

# Define local groups to audit
$groups = "Administrators", "Remote Desktop Users";

# Add Active Directory powershell plug-in
import-module activedirectory;

# Get all servers from AD and ignore predefined list 
$adservers = get-adcomputer -filter {operatingsystem -like "*server*"} | where {$_.enabled -eq $true} | sort name;

# Loop through each server found in AD
foreach ($adserver in $adservers) {


# Set server name from AD object
$servername = $adserver.name;

# Check if server is pingable
if((test-connection -computername $servername -count 1 -quiet)) {

    # Loop through each group to audit
    foreach ($group in $groups) {

        # Define the localgroup in the correct format
        $localgroup = [ADSI]"WinNT://$servername/$group";

        # Get members of the local group
        $members = @($localgroup.Invoke("Members"));

        # Loop through each member found
        foreach ($member in $members) {

            # Define name and type of the member
            $memberName = $member.GetType().Invokemember("Name","GetProperty",$null,$member,$null);
            $memberType = $member.GetType().Invokemember("Class","GetProperty",$null,$member,$null);

            # Build CSV string
            $outstring = $servername + "," + $group + "," +$membername + "," +$membertype;
            # Output string to screen
            write-host $outstring;

            # Append CSV string to file
            $outstring >> c:\temp\localgroupaudit.csv;
        }
    }
  }
}

1 Ответ

0 голосов
/ 15 ноября 2018

Целое из:

        # Build CSV string
        $outstring = $servername + "," + $group + "," +$membername + "," +$membertype;
        # Output string to screen
        write-host $outstring;

Если запись на экран не является чем-то, что вам нужно, измените на:

[Array]$results = $results + [PSCustomObject]@{Servername=$servername; LocalGroupName=$group,Members=$membername,Type=$membertype}

И после окончания всех ваших циклов:

$results | Export-CSV C:\path\youwanto\exportfileto\filenamehere.csv -notypeinformation
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...