【问题标题】:PowerShell Compare-Object and Export-Csv exporting wrong dataPowerShell Compare-Object 和 Export-Csv 导出错误数据
【发布时间】:2021-01-09 22:57:14
【问题描述】:

问题

我有两个 CSV 文件,文件 A 和文件 B。这两个文件包含相同的标题。
这些文件包含有关报价和订单的信息。

首先创建文件 A,假设是上午 10:00。文件 B 于上午 11:00 创建。那是状态列值从“报价”更新为“订单”的时候,可能还有其他一些详细信息。

我使用 Compare-ObjectExport-Csv 组合将差异导出到新的 CSV 文件,但只应导出最新(最新)信息。
问题是:Compare-Object 正确检测到特定行已更改,但不是使用文件 B 中的数据,而是使用文件 A(旧版本)中的数据。

示例(文件内容)

我以粗体突出显示了更改的字段。

文件 A

"CustomerName","Address","Postalcode","City","ReferenceNumber","CustomerNumber","Statuscode","DeliveryWeek","WorkDescription","Status","OrderReference","Advisor" "Example Customer","Example Address 1","9999 EX","EXAMPLE CITY","217098","8629",**"Quote"**,**""**,"Example Product","示例状态","私人","示例顾问"

文件 B

"CustomerName","Address","Postalcode","City","ReferenceNumber","CustomerNumber","Statuscode","DeliveryWeek","WorkDescription","Status","OrderReference","Advisor" "Example Customer","Example Address 1","9999 EX","EXAMPLE CITY","217098","8629",**"Order"**,**"Call-off"**,"Example Product ","示例状态","私人","示例顾问"

脚本

好的,那里有很多台词。我将分享我认为问题应该存在的地方。

$timestamp = (get-date -UFormat "%A %d-%m-%Y %R" | ForEach-Object { $_ -replace ":", "-" })
$prefix="Export-"
$exportlocation = "C:\Users\username\Desktop\UTF8-format\" 
$ExportChangesFolder = "C:\Users\username\Desktop\Changes\"

$PreviousCSV = Import-Csv $PreviousFile -Header "CustomerName","Address","Postalcode","City","ReferenceNumber","CustomerNumber","Statuscode","DeliveryWeek","WorkDescription","Status","OrderReference","Advisor"
$NewCSV = Import-Csv $exportlocation$prefix$timestamp".csv" -Header "CustomerName","Address","Postalcode","City","ReferenceNumber","CustomerNumber","Statuscode","DeliveryWeek","WorkDescription","Status","OrderReference","Advisor"

$propsToCompare = $PreviousCSV[0].psobject.properties.name
Compare-Object -ReferenceObject $PreviousCSV -DifferenceObject $NewCSV -Property $propsToCompare -PassThru | select $propsToCompare | sort -Unique -Property "ReferenceNumber" | Select-Object * -ExcludeProperty SideIndicator | Export-Csv $ExportChangesFolder$prefix$timestamp".csv" -NoTypeInformation 

通常,所有文件名都会自动填充,因为这是使用 Windows 任务计划程序的重复任务设置。在故障排除期间,我手动填写了声明变量的文件名。而且每次我手动运行它都可以正常工作!

【问题讨论】:

    标签: powershell csv compareobject


    【解决方案1】:

    我认为您可能缺少的是SideIndicator。您应该可以只选择您想要的SideIndicators 列表,其中“<=”是仅存在于左侧 csv 中的内容,而“=>”是仅存在于右侧的内容。

    您似乎也在指定标头,然后从 csv 中获取标头,但您提到它们具有相同的标头?

    Get-Date 在运行时针对Import-Csv 的现有文件也有点令人困惑,但我猜在导入和Get-Date 运行之前构建此csv 的脚本还有更多内容。

    这是我正在做的事情:

    $timestamp = ((get-date -UFormat "%A %d-%m-%Y %R") -replace ":", "-")
    $prefix="Export-"
    $exportLocation = "C:\Users\username\Desktop\UTF8-format\" 
    $exportChangesFolder = "C:\Users\username\Desktop\Changes\"
    
    $headers = $previousCSV[0].psobject.properties.name
    
    $previousCSV = Import-Csv $previousFile
    $newCSV = Import-Csv $exportLocation$prefix$timestamp".csv"
    
    $compareParams = @{
        ReferenceObject  = $previousCSV
        DifferenceObject = $newCSV
        Property         = $headers
        PassThru         = $true
    }
    
    Compare-Object @compareParams |
        Where-Object {$_.SideIndicator -eq "=>"} |
        Select-Object $headers | 
        Sort-Object -Unique -Property "ReferenceNumber" | 
        Select-Object * -ExcludeProperty SideIndicator |
        Export-Csv $exportChangesFolder$prefix$timestamp".csv" -NoTypeInformation
    

    【讨论】:

    • 你好安德鲁,谢谢!我仔细研究了如何使用 SideIndicator,似乎当我包含 {$_.SideIndicator -eq "=>"} 时,它只会在 ReferenceNumber 仅存在于文件 B 中时传递信息。在我的情况下,ReferenceNumber 将两个文件中都存在,但状态值将在 B 中更新。我是否正确,因此使用 {$_.SideIndicator -eq "=>"} 不会导致预期的结果? “...一个属性值只出现在引用对象()中。如果使用IncludeEqual参数,(==)表示该值在两个对象中。”跨度>
    • 我想我这次做对了!我对这个比较对象的东西很陌生。因为我们包含 Select-Object * 它会将所有属性视为一个整体(对象),对吗?正如您所建议的,拼图的缺失部分显然是 SideIndicator。感谢您的帮助,这真的很清楚。现在我也看到我的代码的某些部分确实过时和/或不必要。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2013-10-11
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-04-30
    • 2021-01-16
    • 1970-01-01
    相关资源
    最近更新 更多