0

我通过运行下面的脚本并将结果写入文本文件来比较两个冗长的文本文件。我得到的不是预期的标准比较对象输出,而是它的一部分,其他所有内容都被修剪(由于最大字符限制或格式模板或其他原因)。任何想法如何将原始输出写入文件或增加一行中的字符限制以获得正确的结果?我比较的文件不能以任何方式缩短或重新格式化,也许我可以使用其他东西代替比较对象功能?

谢谢!

脚本:

    function compareConfigs {

    Try{
        $compareOne = Get-Content $azConfig
        $comparetwo = Get-Content $dummyConfig
    } 
    Catch{
        Write-Host "Path is invalid or the file does not exist. "    
    }

Write-Host "Beginning comparison"
$Compare = Compare-Object $compareOne $compareTwo

$compare | foreach  { 
    if ($_.sideindicator -eq '<=')
        {$_.sideindicator = $azConfig}

    if ($_.sideindicator -eq '=>')
        {$_.sideindicator = $dummyConfig}
    }

$Compare | 
select @{l='Value';e={$_.InputObject}},@{l='File';e={$_.SideIndicator}} |
Out-File $compareResult

Write-Host "Complete!"
}

compareConfigs

输出:

InputObject                                                                                                                                                                          
-----------                                                                                                                                                                          
      <add fileName="E:\Logs\LeadManagement\LeadService.log" rollSizeKB="4096" timeStampPattern="yyyy-MM-dd" rollFileExistsBehavior="Increment" rollInterval="Day" formatter="Text...
      <add template="Timestamp: {timestamp}&#xA;Message: {message}&#xA;Category: {category}&#xA;Priority: {priority}&#xA;EventId: {eventid}&#xA;Severity: {severity}&#xA;Title:{ti...
      <add fileName="E:\Logs\LeadManagement\LeadService.log" rollSizeKB="4096" timeStampPattern="yyyy-MM-dd" rollFileExistsBehavior="Increment" rollInterval="Day" formatter="Text...
      <add template="Timestamp: {timestamp}&#xA;Message: {message}&#xA;Category: {category}&#xA;Priority: {priority}&#xA;EventIwefwefd: {eventid}&#xA;Severity: {severity}&#xA;Tit...
4

1 回答 1

1

由于您使用的是选择对象,因此您会看到生成的 $Compare 是一个 PSCustomObject 类型。相反,使用 Foreach-Object (%) ...

$Compare | %{($_.InputObject + "`t" + $_.SideIndicator)} | Out-File $compareResult

请注意,我在这里使用制表符“`t”作为分隔符。

如果您希望以 CSV 格式输出,您可以使用现有的,只需使用 Export-CSV 而不是 Out-File ...

$Compare | select @{l='Value';e={$_.InputObject}},@{l='File';e={$_.SideIndicator}} | Export-CSV -Notype compareResult.csv
于 2017-05-02T02:57:55.967 回答