利用CanonicalName选择专有名称

时间:2017-03-15 23:22:51

标签: powershell export-to-csv powershell-v4.0

我想使用canonicalname而不是专有名称,因为在csv中排序的原因要清晰得多。
我知道我必须把属性值,但问题是在哪里。我不知道它是否在$ oulist或$ users变量中。这是我的代码。

Import-Module activeDirectory
$output = Read-Host "'Y' for output to file or any key for output in GUI table view" -foreground Cyan
$fqdn = Read-Host "Enter FQDN domain"
$cred = Get-Credential

Write-Host "Contacting $fqdn domain..." -ForegroundColor Yellow

$domain = (get-addomain $fqdn -Credential $cred | select distinguishedName, pdcEmulator, DNSroot, DomainControllersContainer)

Write-Host "Completed. Enumerating OUs.." -ForegroundColor Yellow

$OUlist = @(Get-ADOrganizationalUnit -filter * -Credential $cred -SearchBase $domain.distinguishedName -SearchScope Subtree -Server $domain.DNSroot)
Write-Host "Completed. Counting users..." -ForegroundColor Yellow

$newlist = foreach ($OU in $OUlist)
{
#The array will automatically have a count property, no need for measure
$Users = Get-ADuser -Filter * -Credential $cred -SearchBase $OU.DistinguishedName -SearchScope OneLevel -Server $domain.pdcEmulator
#Again you already have all of the user object before the loop, just            write-progress for the OUlist that you are looping through
write-progress -Activity "Counting users" -Status "Finding users in $OU" -PercentComplete ([array]::indexof($OUlist, $OU)/$OUlist.count * 100)
[pscustomobject]@{
    OU = $OU.DistinguishedName; Count = ($Users.Count)

    }
}
if ($output -eq "Y")
{
    $newlist | Export-CSV .\OUuserCount.csv -NoTypeInformation -Force
    Write-Host "All done!" -ForegroundColor yellow
}
else
{
$newList | Out-GridView
}

1 个答案:

答案 0 :(得分:0)

我明白了。我需要做的就是改变两个值。 我添加了canonicalname的属性值

$OUlist = @(Get-ADOrganizationalUnit -filter * -Credential $cred -properties CanonicalName -SearchBase $domain.distinguishedName -SearchScope Subtree    -Server $domain.DNSroot)

我更改了OU的数组值

[pscustomobject]@{
    OU = $OU.CanonicalName; Count = ($Users.Count)

}