Массовый импорт в PowerShell AD

Я пытаюсь импортировать список сотрудников в AD с помощью PowerShell. Сценарий должен обновлять существующие объекты AD.

У меня проблема в том, что некоторые пользователи будут иметь номер мобильного телефона, некоторые внутренние номера, а некоторые просто расширение, когда я запускаю команду Set-ADuser в ее самой простой форме, кажется, что она не работает всякий раз, когда значение пустое.

Я не очень хорошо пишу сценарии, может ли кто-нибудь объяснить мне, почему приведенный ниже сценарий не работает? И если да, может ли кто-нибудь подсказать, как заставить его работать? Ура!

Import-module ActiveDirectory

$CSVPath = "c:\scripts\ictdepartment2.csv" 
$csvData = Import-CSV $CSVPath -delimiter "," -Header ("SamaccountName","identity","Title","Company","Department","Description","Office","OfficePhone","IPPhone","MobilePhone") 


##

foreach ($line in $csvData) 
{
$accountTable = @{ 
'SamaccountName'= $line.SamaccountName 
'identity'= $line.identity
'title'= $line.title 
'company'= $line.company 
'department'= $line.department 
'description'= $line.description 
'office'= $line.office
'officephone'= $line.officephone 
'IPPhone'= $line.ipPhone 
'mobilephone'= $line.mobilephone 
}
}

##

ForEach($line in $csvData) 
{
$SamaccountName = $line.SamaccountName
$identity = $line.identity
$title = $line.title 
$company = $line.company 
$department = $line.department 
$description = $line.description 
$office = $line.office
$officephone = $line.officephone
$IPPhone = $line.ipPhone 
$mobilephone = $line.mobilephone 
}

##

ForEach($line in $csvData) 
{
if ($officephone -ne $null)
{Set-ADUser -Identity $SamaccountName -OfficePhone $officephone}
if ($mobilephone -ne $null)
{Set-ADUser -Identity $SamaccountName -MobilePhone $mobilephone}
if ($ipphone -ne $null)
{Set-ADUser -Identity $SamaccountName -replace @{ipPhone=$ipphone}}

Set-ADUser -Identity $SamaccountName -Company $Company -Department $Department -Description $Description -Office $office -Title $title
}

Если я использую следующие команды, он работает, однако, как только я добавляю в него оператор if $ null, он снова терпит неудачу: (

ForEach($line in $csvData) 
{ 
Get-ADUser -Filter "SamAccountName -eq '$($line.samaccountname)'" |
Set-ADUser -Replace @{ipphone=$ipphone}
}

ForEach($line in $csvData) 
{ 
Get-ADUser -Filter "SamAccountName -eq '$($line.samaccountname)'" |
Set-ADUser -Company $Company -Department $Department -Description $Description -MobilePhone $mobilephone -Office $office -OfficePhone $officephone -Title $title
}
1
задан 12 November 2015 в 16:52
1 ответ

$ null и пустая строка ("") - это два разных типа данных для PowerShell. Замените любой экземпляр $ null на "" , и все будет хорошо. Почти все командлеты, предоставленные MS, имеют значение [ValidateNotNull] .

Я хотел бы немного рассказать о том, что такое $ Null . Powershell - это оболочка ООП (объектно-ориентированного программирования) с прямым подключением к .Net. $ Null - это заполнитель и самостоятельный объект, который ничего не представляет. Не беспокойтесь о полном понимании $ Null на данный момент, многие люди (даже некоторые программисты) не понимают $ Null в N-й степени.

Итак, почему это актуально сейчас? Позвольте мне связать вас с ЭТОЙ СПРАВОЧНИК , но я скопирую здесь соответствующую информацию ...

... вы не можете использовать $ null для обозначения «без значения параметра». Параметр значение $ null переопределяет значение параметра по умолчанию.

В вашем случае вы пытаетесь приравнять содержимое одной переменной к объекту $ Null , оно никогда не будет совпадать, потому что только $ Null равно -eq к $ Null .

Пустая строка ("") - это объект String без значения.Вот почему вы хотите использовать его с операторами сравнения (-eq, -lt, -ge) для оценки других строк.

5
ответ дан 3 December 2019 в 17:04

Теги

Похожие вопросы