如何让PowerShell将错误消息导出到CSV?

问题描述 投票:0回答:1

我正在尝试修改 PowerShell 脚本以在 CSV 文件中附加错误。一位前同事创建了一个脚本,用于从 txt 文件中获取计算机名称,浏览 Active Directory,并使用生成的分区和规范名称创建 CSV 文件(如果有帮助的话,创建 Excel 文件)。 CSV 文件有三列; “Name”,直接保存txt文件中的名字; “部门”(取自 AD 中的“名称”),包含系统所属部门/部门的名称;和“CanonicalName”,它保存 AD 中显示的每个系统的完整规范名称。有时,计算机在 AD 中没有条目,它会向主机抛出一条错误消息,并且该系统将从 CSV 文件中丢失。下面是修改后的脚本,出于隐私原因,文件路径将显示为“文件路径”并且不显示实际的文件路径。

这是我目前拥有的:

$ComputerList = Get-Content "File Path"
$Date = Get-Date -Format dd-MM-yyyy

foreach ($Computer in $ComputerList)
{
    if (@(Get-ADComputer $Computer -ErrorAction SilentlyContinue).Count) #Check if computer exists in AD
    {
       Get-ADComputer -Identity $Computer -Properties * | Select Name, @{n='Division'; e={([string]$_.o)}}, CanonicalName |
       Export-Csv "File Path" -NoTypeInformation -Append
    }
    else #Annotate if computer does not exist in AD
    {
       $NoComputer = [PSCustomObject]
       @{
          Name = $Computer
          Division = "Object Not Found"
          CanonicalName = " "
       }
       
       $CSVData = $NoComputer | ConvertTo-Csv -NoTypeInformation
       $CSVData | Select-Object -Skip 1 |
       Export-Csv "File Path" -NoTypeInformation -Append #<-- Error happens on this line, according to host
    }
}

运行如上所示的脚本时,它仍然会向主机抛出错误消息,以及每个缺失系统的两列,如下所示(出于隐私原因未显示实际计算机名称):

Name                           Value                                                                                                                                                          
----                           -----                                                                                                                                                          
Name                           ComputerName                                                                                                                  
CanonicalName                                                                                                                                            
Division                       Object Not Found

它还会在主机中抛出以下错误消息:

Export-Csv : Cannot append CSV content to the following file: File Path\Computer 
Identity List.csv. The appended object does not have a property that corresponds to the following column: Name. To continue with mismatched properties, add the -Force parameter, and then 
retry the command.
At File Path.ps1:36 char:8
+        Export-Csv File Path
+        ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    + CategoryInfo          : InvalidData: (Name:String) [Export-Csv], InvalidOperationException
    + FullyQualifiedErrorId : CannotAppendCsvWithMismatchedPropertyNames,Microsoft.PowerShell.Commands.ExportCsvCommand

然后,当我希望它列出系统并附加它在 CSV 文件的“分区”列中找不到带有“未找到对象”的系统时,它会在 CSV 文件中忽略该系统。我尝试执行 -Force,但它只是创建一个空白行。根据我查到的内容,这应该有效,但显然我错过了一些东西。为了使这项工作正常进行,我需要改变什么?

powershell error-handling active-directory export-to-csv
1个回答
0
投票

更改您的逻辑以使用

try / catch
而不是
if / else
Get-ADComputer
不会尊重
-ErrorAction
,除非您通过管道输入它。您还可以通过仅查询感兴趣的属性(
o
canonicalName
)而不是所有属性(
*
)来提高脚本的性能,并且还可以在导出输出而不是附加到输出之前构建输出。

$result = foreach ($Computer in $ComputerList) {
    $object = [pscustomobject]@{
        Computer      = $computer
        Division      = ''
        CanonicalName = ''
    }

    try {
        $adcomputer = Get-ADComputer $Computer -Properties o, canonicalName
        $object.Division = [string] $adcomputer.o
        $object.CanonicalName = $adcomputer.CanonicalName
    }
    catch {
        $object.Division = 'Object Not Found'
        $object.CanonicalName = ' '
    }

    $object
}

$result | Export-Csv 'File Path' -NoTypeInformation
© www.soinside.com 2019 - 2024. All rights reserved.