温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Powershell-批量互换域用户属性信息

发布时间:2020-03-27 03:01:23 来源:网络 阅读:826 作者:wenzhongxiang 栏目:系统运维

需求描述:

因生产环境数据接口需求,需要对某时间段已上线用户属性进行批量互换,涉及字段EmployeeNumber,EmployeeID

环境信息:

Windows Server 2012 R2 ActiveDirectory

操作步骤:

PS.操作之初,建议先对当前环境属性字段进行备份导出操作。

方法一:

1.过滤出某时间段创建帐户信息,并导出域帐号EmployeeNumber,EmployeeID字段;

$date=Get-Date
$oldday=(Get-Date).AddDays(-180)
Get-ADUser -Filter * -Properties * -SearchBase "OU=Old,OU=Staff,DC=a,DC=com" |?{$_.whenCreated -le $date -and $_.whenCreated -ge $oldday} |`
Select-Object name,samaccountname,userPrincipalName,EmployeeNumber,EmployeeID | `
Export-Csv C:\New0505.csv -Encoding UTF8 -NoTypeInformation

Powershell-批量互换域用户属性信息

2.将表格数据进行按需调整,去掉ID字段为空的用户信息,并保存CSV文本格式为utf8

3.执行导入用户信息操作,并查看当前各字段对应信息属性

Import-Csv 'C:\New0505.csv' | select SamAccountName,EmployeeNumber,EmployeeID

4.如信息无误,执行批量替换操作

4.1如ID与Number字段位置无调整,执行如下命令:

Import-Csv 'C:\New0505.csv' | ForEach-Object { Set-ADUser -Identity $_.SamAccountName -EmployeeNumber $_.EmployeeID -EmployeeID $_.EmployeeNumber }

4.2如ID与Number字段已调整,则按照正常替换格式替换,执行如下命令:

Import-Csv 'C:\New0505.csv' | ForEach-Object { Set-ADUser -Identity $_.SamAccountName -EmployeeNumber $_.EmployeeNumber -EmployeeID $_.EmployeeID }

Powershell-批量互换域用户属性信息

查看替换后属性字段信息

Import-Csv 'C:\New0505.csv' | ForEach-Object { get-ADUser -Identity $_.SamAccountName -Properties * |select SamAccountName,EmployeeNumber,EmployeeID }

5.完成替换操作



方法二:

PS.如当前环境中数据均无须调整,可直接执行替换操作,具体如下:

1.以OU为例介绍,查看当前OU下用户相关属性:

Get-ADUser -SearchBase "OU=Old,OU=Staff,DC=a,DC=com" -Filter * -Properties * |select SamAccountName,EmployeeNumber,EmployeeID

2.执行批量互换当前属性操作:

Get-ADUser -SearchBase "OU=Old,OU=Staff,DC=a,DC=com" -Filter * -Properties * |select SamAccountName,EmployeeNumber,EmployeeID |ForEach-Object { Set-ADUser -Identity $_.SamAccountName -EmployeeNumber $_.EmployeeID -EmployeeID $_.EmployeeNumber }

3.再次查看当前OU下用户属性,发现用户属性已变更完成。

Get-ADUser -SearchBase "OU=Old,OU=Staff,DC=a,DC=com" -Filter * -Properties * |select SamAccountName,EmployeeNumber,EmployeeID

Powershell-批量互换域用户属性信息


综合:对方法一脚本进行优化操作,批量互换某时间段用户属性字段信息:

$date=Get-Date
$oldday=(Get-Date).AddDays(-180)
Get-ADUser -Filter * -Properties * -SearchBase "OU=Old,OU=Staff,DC=a,DC=com" |?{$_.whenCreated -le $date -and $_.whenCreated -ge $oldday} |`
Select-Object name,samaccountname,userPrincipalName,EmployeeNumber,EmployeeID |
forEach-Object { Set-ADUser -Identity $_.SamAccountName -EmployeeNumber $_.EmployeeID -EmployeeID $_.EmployeeNumber }

Powershell-批量互换域用户属性信息

完成本次需求操作。

欢迎关注微信公众号:小温研习社

Powershell-批量互换域用户属性信息

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI