powershell 移动OU

本文介绍了一个PowerShell脚本,用于从CSV文件中读取计算机名列表,并将这些计算机批量移动到Active Directory的目标组织单位(OU)。脚本还包含了日志记录功能及CSV文件管理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<#
此脚本通过读取计算机名列表文件,移动其到目标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文件

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值