1

我编写了一个通过 AD 终止过程运行的扩展脚本,该脚本可以从 CSV 中获取必要的信息。如果 CSV 中的条目为空白,我该如何制作它以使其出错?我尝试使用 Try-Catch、If-Else 以及我知道如何做的所有事情。我已经尝试更改错误操作,并且可以让它抛出系统生成的错误(例如“无法将参数“Identity”绑定到目标......”),但我无法让它做我想做的事。请看下面的代码示例:

(是的,我知道我在重复值。这在脚本后面很重要,而不是我遇到问题的部分)

    $owner = $user.'Network User ID'}
    $loginID = $user.'Network User ID'
    $Identity = Get-ADUser -Identity $owner -Properties Displayname |Select-Object -ExpandProperty Displayname 
    $manager = $user.'Provide Inbox Access To'
    $NewOwner = $user.'Provide users email group ownership to'
    $NewOwnerID = $User.'Provide users email group ownership To'

如果 CSV 中的任何条目为空白,我需要它做的是抛出一个错误,然后终止。我尝试过的最有希望的想法是:

    If ($Owner -eq $Null)
    {
    Write-Host "Invalid entry, the Network User ID field cannot be blank"
    Write-Host "Press Enter to Exit..."
    Exit
    }
    Else
    {
    #Do everything else
    }

但即使这样仍然失败。

总之,如果 CSV 中的条目为空白,我需要做的是引发自定义终止错误。

任何帮助是极大的赞赏!

编辑

如果这有帮助,这里有更多真正的代码......

$Confirmation = Read-Host "Please double check the information in the file. Are you sure you want to continue? (Y/N)"

If($Confirmation -eq "Y")
{
Write-Host "You have chosen to proceed. Processing Termination" -BackgroundColor DarkCyan
#Import file
$file = "C:\TerminateUsers.csv"
$data = Import-Csv $file
#Set disabled OU
$disabledOU = "OU=Users,OU=Disabled Accounts, OU=Corporate"

$colOutput = @()
foreach ($user in $data)
{
    #Grab variables from CSV
    $owner = $user.'Terminated Network User ID'}
    $loginID = $user.'Terminated Network User ID'

    #Displayname required for Outlook functions
    $Identity = Get-ADUser -Identity $owner -Properties Displayname |Select-Object -ExpandProperty Displayname 
    $manager = $user.'Provide Inbox Access To'
    $NewOwner = $user.'Provide users email group ownership to'
    $NewOwnerID = $User.'Provide users email group ownership To'
    If (Get-ADUser -LDAPFilter "(sAMAccountName=$loginID)")
        {
        $date = Get-Date -Format d
        #Disable account, change description, disable dialin, remove group memberships
        Set-ADUser -Identity $loginID -Enabled $false
        Set-ADUser -Identity $loginID -Replace @{Description = "Terminated $date"}
        Set-ADUser -Identity $loginID -Replace @{msNPAllowDialin = $False}
        RemoveMemberships $loginID 

这不是全部,但这是我们正在处理的部分......

4

2 回答 2

3

您将在这里遇到许多问题。

首先,$Owner -eq $Null不会做你可能想做的事。主要问题是空字符串不是空值。他们是不同的。相反,您的测试应该是:

if ([string]::IsNullOrEmpty($owner)) { ... }

或者:

if ([string]::IsNullOrWhiteSpace($owner)) { ... }

如果字符串仅包含制表符、空格或其他空白字符,或者是空字符串,或者为 null,则第二个返回 true。

其次,要抛出异常,需要使用throw关键字。见Get-Help about_Throw。例如:

if ([string]::IsNullOrWhiteSpace($owner)) {
    throw "Owner is null or empty.";
}

如果您将此嵌入到try块中,则可以使用关联的catch块捕获异常。见Get-Help about_Try_Catch_Finally。你也可以使用Trap,我相信(见Get-Help about_Trap)。

最后,遇到错误时的默认操作由$ErrorActionPreference变量控制。该变量的默认值为Continue,因此将显示错误消息,但脚本将继续执行,就好像根本没有发生错误一样。我不完全确定这如何与手动抛出的异常和 try/catch 块一起工作,但除非我知道我希望我的脚本忽略错误,否则我几乎从每个脚本开始:

$ErrorActionPreference = Stop;

请参阅Get-Help about_Preference_VariablesGet-Help about_CommonParameters了解有关此的更多信息。

于 2015-10-28T12:34:46.737 回答
2

考虑以下数据集。请注意其中一列的 Last_Name 为空。

user_name  first_name last_name
---------  ---------- ---------
lrivera0   Lawrence   Rivera   
tlawrence1 Theresa    Lawrence 
rboyd2     Roy                 
cperry3    Christine  Perry    
jmartin4   Jessica    Martin  

所以如果我们想确保只处理完整的行,那么一个简单的If就可以了。

Import-Csv .\text.csv | ForEach-Object{
  If($_.Psobject.Properties.Value -contains ""){
     # There is a null here somewhere
     Throw "Null encountered. Stopping"
  } else {
    # process as normal
  }
}

问题是Import-CSV将空值视为零长度字符串。我尝试使用-containson just$_但它不起作用,因为$_它不是数组而是具有属性的对象。所以我使用对象属性value来进行比较。

Bacon 提出了一个有趣的观点,即这段代码不会只考虑空白值。

throw如果遇到空值,我们使用so 处理停止。使用该 if 块,您可以执行任何您想要的操作。

于 2015-10-28T12:33:16.177 回答