powershell比较对象输出问题

时间:2017-05-02 00:31:44

标签: powershell format text-files pipeline compareobject

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

谢谢!

脚本:

    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...

1 个答案:

答案 0 :(得分:1)

由于您正在使用select-object,您将看到生成的$ 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