[英]Active Directory and Powershell
我目前正在将VB中的脚本重写为Powershell脚本。
脚本的作用是根据脚本用户输入在Active Directory中搜索用户。
Function PromptForName{
$nameInput = "*"
$nameInput += Read-Host ("Please enter a full or partial name.")
$nameInput += "*"
return $nameInput
}
Function FindUsers{
param ([string]$n)
$usersArray = Get-ADUser -f {DisplayName -like $n} | Select-Object Name
return $usersArray
}
此代码将打印出正确的名称列表。 然后,我想做的就是允许用户选择这些名称之一,并获得有关该人的更多信息。 我坚持允许脚本用户选择这些名称之一。
我如何提示再次输入; 该框将在其中显示FindUsers给出的所有名称的编号列表,然后根据他们选择的用户返回一个数字? 我完全迷路了。
尽管我很确定这是完全错误的,但目前这是我正在尝试的方法。
Function PrintUsers{
param $a
[int]$i, $j
[string]$userList
$j = 1
foreach($object in $array){
$userList += ($j + $array[$i])
$j++
}
return $userList
}
Function SelectUser{
param $list
$user = Read-Host ($list)
}
编辑:
我已经将功能更新为以下内容:
Function FindUsers{
param ([string]$n)
$usersArray = @(Get-ADUser -f {DisplayName -like $n} | Select-Object Name| Format-List)
return $usersArray
}
Function PrintUsers{
param ([String[]]$array)
$i
for($i = 1; $i -lt $usersArray.length; $i++){
Write-Host "$i. $($usersArray[$i-1].Name)"
}
}
FindUsers之后的输出是这样的:名称:xxxxx yyyyy名称:xxxxx zzzzz等。
因此,$ usersArray的返回将显示所有内容。 在PrintUsers函数之前,我不需要任何打印,并且希望它采用如下编号列表类型的格式:1. xxxx yyyy 2. xxxx zzzz等。
我最困难的时间来解决这个问题。
# get all users
$usersArray = @(Get-ADUser -f {DisplayName -like $n} )
# create menu
for($i=1; $i -le $usersArray.count; $i++){
Write-Host "$i. $($usersArray[$i-1].Name)"
}
# prompt for user number
$user = Read-Host Enter the user number to get more info
# display full info for selected user
$usersArray[$user-1] | Format-List *
使用“添加成员”向每个用户添加唯一标识符。 举例来说,让我们将流程视为用户对象:
$procs = gps;
$procs = $procs | % { $i=0; } {
Add-Member -MemberType NoteProperty -InputObject $_ -Name Number -Value $i -PassThru;
$i++;
};
$procs | select Number,Name;
$procid = Read-Host -Prompt 'Enter the number of the process you would like to operate on';
$proc = $procs | ? { $_.Number -eq $procid };
Write-Host -Object ('Operating on proc: {0}' -f $proc.Name);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.