<#
此脚本通过读取计算机名列表文件,移动其到目标OU。
#>
$MoveList=Import-Csv -Path "D:\GroupPolicy\GetComputerName\ComputerList\Computers.csv"
#读取内容为计算机名的csv文件
$TargetOU='OU=MS,OU=Computers,OU=SHA,OU=xxx,DC=xxxxx,DC=com'
#定义目标OU
$computers=Get-ADComputer -Filter * -SearchBase $TargetOU|select name
#获取目标OU中的计算机
$time=(Get-Date).ToString('yyyyMMdd')
#定义时间格式
foreach ($Computer in $MoveList){
#遍历CSV文件中的计算机名,并比较它是否已经在目标OU中
#如果已经在目标OU,则不操作;不在,将其移到目标OU
if ($Computer -notin $computers.name) {
Move-ADObject -Identity (Get-ADComputer $Computer.CN).DistinguishedName -TargetPath $TargetOU
#这里 $computer.CN 中的CN是列名,可以自己定义。或者不适用CSV格式,直接TXT比较省事。
$log_content=($Computer.CN)+"`t"+"$time"
Out-File -InputObject $log_content -FilePath "E:\Script_Logs\TaskScheduler\Move_Computers\$time.txt" -Append
#写日志,只记录成功移动的机器
}
}
$error_log=$time+'_'+'Error'
Out-File -InputObject $Error -FilePath "E:\Script_Logs\TaskScheduler\Move_Computers\$error_log.txt"
#记录错误日志
Remove-Item D:\GroupPolicy\GetComputerName\ComputerList\Computers.csv
New-Item -type file -Path D:\GroupPolicy\GetComputerName\ComputerList -Name Computers.csv
Add-Content D:\GroupPolicy\GetComputerName\ComputerList\Computers.csv "CN"#因为CSV文件第一行为列名
#避免CSV文件越来越大,所以每执行一次就删除并重建一次CSV文件
powershell 移动OU
最新推荐文章于 2024-04-09 08:47:08 发布