我正在尝试修改 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,但它只是创建一个空白行。根据我查到的内容,这应该有效,但显然我错过了一些东西。为了使这项工作正常进行,我需要改变什么?
更改您的逻辑以使用 a
try / catch
而不是 anif / else
,除非您通过管道输入它,否则Get-ADComputer
不会尊重 the 。-ErrorAction
您还可以通过仅查询感兴趣的属性 (o
和canonicalName
) 而不是所有属性 (*
),以及在导出输出之前构建输出而不是附加到输出来提高脚本的性能。您的行中还有一个拼写错误
[PSCustomObject]
,哈希表 (@{ ... }
) 必须与类型加速器位于同一行,这会导致当您将它们导出到 Csv 时出现属性不匹配$NoComputer
错误,该变量被分配的类型PSObject
而不是您的实际类型目的。