我正在尝试修改 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,但它只是创建一个空白行。根据我查到的内容,这应该有效,但显然我错过了一些东西。为了使这项工作正常进行,我需要改变什么?
更改您的逻辑以使用
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