<#
此脚本通过读取计算机名列表文件,移动其到目标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
powershell 移动OU
最新推荐文章于 2021-07-04 10:19:46 发布