使用PowerShell从CSV文件更新AD用户

loading...


0

我正在使用PowerShell脚本向AD中的所有用户添加一些信息 . 出于某种原因,如果用户的名字中有撇号(例如Tim O'Reilly),我会不断收到错误消息 .

如何格式化脚本以使其包含带撇号的名称?

我的剧本:

# Import AD Module
Import-Module ActiveDirectory

write-Host 'Starting to update AD Attributes.......' -NoNewline -ForegroundColor Yellow
# Import CSV into variable $users

$users = Import-Csv -Path C:\Scripts\users.csv

# Loop through CSV and update users if the exist in CVS file

foreach ($user in $users) {
#Search in specified OU and Update existing attributes
Get-ADUser -Filter "displayName -eq '$($user.Name)'" -Properties * -SearchBase "DC=My,DC=domain,DC=com" |
Set-ADUser -Company $($user.Email)
}

Write-Host 'done!' -ForegroundColor Green

这是我得到的错误信息:

Get-ADUser:解析查询时出错:'displayName -eq'Tim O'Reilly''错误消息:'语法错误'位置:'29' . 在C:\ Scripts \ Update-information \ Update-Users-2.ps1:13 char:1 Get-ADUser -Filter“displayName -eq'$($ user.Name)'” - Properties * -S ...〜 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ ~~~~~~~~~~~~~~~~~~分类信息:ParserError:(:) [Get-ADUser],ADFilterParsingException FullyQualifiedErrorId:ActiveDirectoryCmdlet:Microsoft.ActiveDirectory.Management.ADFilterParsingException,Micr osoft.ActiveDirectory.Management .Commands.GetADUser

我真的很感激我能得到的任何帮助 .

谢谢,

1回答

  • 1

    您可以在csv文件中使用一些自定义分隔符,而不是修改脚本 . 只需将数据与“:”(Tim:O'Reilly)等自定义字符分开,并为import-csv cmdlet添加分隔符开关,如

    $users = Import-Csv -Path C:\Scripts\users.csv -Delimiter :
    

loading...

评论

暂时没有评论!