Powershell-CompareCsv-Export-Values-From-Each我发布了该问题,其内容几乎相同,除了我的右CSV具有多个具有相同的“第一”,“最后”和“ DOB”的行,但是文件名不同,而我的“左文件”仅具有“第一”,最后,DOB一次。
我认为答案会有所不同,以至于我决定发布第二个问题。
我有2个CSV
left.csv
Ref_ID,First_Name,Last_Name,DOB
321364060,User1,Micah,11/01/1969
946497594,User2,Acker,05/28/1960
887327716,User3,Aco,06/26/1950
588496260,User4,John,05/23/1960
565465465,User5,Jack,07/08/2020
right.csv
First_Name,Last_Name,DOB,City,Document_Type,Filename
User1,Micah,11/01/1969,Parker,Transcript,T4IJZSYO.pdf
User1,Micah,11/01/1969,Parker,Letter,BADBADC.pdf
User1,Micah,11/01/1969,Parker,Resume,AJMLMOC.pdf
User2,Acker,05/28/1960,,Transcript,R4IKTRYN.pdf
User3,Aco,06/26/1950,,Transcript,R4IKTHMK.pdf
User4,John,05/23/1960,,Letter,R4IKTHSL.pdf
我需要在First_Name,Last_Name,DOB上进行匹配,然后从左侧返回Ref_ID。csv,从右侧返回First,Last,DOB,Document_Type,Filename。csv每行。
因此最终结果将如下所示:
Combined.csv
Ref_ID,First_Name,Last_Name,DOB,Document_Type,Filename
321364060,User1,Micah,11/01/1969,Transcript,T4IJZSYO.pdf
321364060,User1,Micah,11/01/1969,Letter,BADBADC.pdf
321364060,User1,Micah,11/01/1969,Resume,AJMLMOC.pdf
946497594,User2,Acker,05/28/1960,Transcript,R4IKTRYN.pdf
887327716,User3,Aco,06/26/1950,Transcript,R4IKTHMK.pdf
588496260,User4,John,05/23/1960,Letter,R4IKTHSL.pdf
使用其他帖子的答案,只会返回第一个匹配项。 我尝试将-eq更改为-in,这会给我所有匹配项,但返回的结果如下:
Ref_ID,First_Name,Last_Name,DOB,Document_Type,Filename
321364060,{User1,User1,User1},{Micah,Micah,Micah},{11/01/1969,11/01/1969,11/01/1969},{Transcript,Letter,Resume},{T4IJZSYO.pdf,BADBADC.pdf,AJMLMOC.pdf}
以下查询可让我获得每个单独的结果,但是我不知道如何从left.csv中添加所需的REF_ID。
$right.Where( {$_.DOB -in $left.DOB -and $_.First_Name -in $left.First_Name -and $_.Last_Name -in $left.Last_Name}) |
export-csv C:\Combined.csv -notypeinformation
结果:它允许我执行-in,它排除了User5,因为它不匹配,但是我需要返回REF_Id
First_Name,Last_Name,DOB,City,Document_Type,Filename
User1,Micah,11/01/1969,Parker,Transcript,T4IJZSYO.pdf
User1,Micah,11/01/1969,Parker,Letter,BADBADC.pdf
User1,Micah,11/01/1969,Parker,Resume,AJMLMOC.pdf
User2,Acker,05/28/1960,,Transcript,R4IKTRYN.pdf
User3,Aco,06/26/1950,,Transcript,R4IKTHMK.pdf
User4,John,05/23/1960,,Letter,R4IKTHSL.pdf
我觉得我只是想念一个运算符,该运算符会将结果按我需要/想要的方式放置,但是我尝试将-join或-split添加到pscustomobject中,但是没有运气,或者没有count + 1,因此它遍历了这些内容,或嵌套的foreach对象,真的很茫然。
答案 0 :(得分:1)
与我在answer中为Powershell-CompareCsv-Export-Values-From-Each使用Join-Object一样:
$Left = ConvertFrom-Csv @'
First_Name,Last_Name,DOB,City,Document_Type,Filename
User1,Micah,11/01/1969,Parker,Transcript,T4IJZSYO.pdf
User1,Micah,11/01/1969,Parker,Letter,BADBADC.pdf
User1,Micah,11/01/1969,Parker,Resume,AJMLMOC.pdf
User2,Acker,05/28/1960,,Transcript,R4IKTRYN.pdf
User3,Aco,06/26/1950,,Transcript,R4IKTHMK.pdf
User4,John,05/23/1960,,Letter,R4IKTHSL.pdf
'@
$Right = ConvertFrom-Csv @'
Ref_ID,First_Name,Last_Name,DOB
321364060,User1,Micah,11/01/1969
946497594,User2,Acker,05/28/1960
887327716,User3,Aco,06/26/1950
588496260,User4,John,05/23/1960
565465465,User5,Jack,07/08/2020
'@
请注意,我已经交换了
$Left
和Right
。虽然也 可以做RightJoin
,
我建议在PowerShell中的LeftJoin
上使用RightJoin
流视角
$Left | LeftJoin $Right `
-On First_Name,Last_Name,DOB `
-Property Ref_ID,First_Name,Last_Name,DOB,Document_Type,Filename `
| Format-Table
Ref_ID First_Name Last_Name DOB Document_Type Filename
------ ---------- --------- --- ------------- --------
321364060 User1 Micah 11/01/1969 Transcript T4IJZSYO.pdf
321364060 User1 Micah 11/01/1969 Letter BADBADC.pdf
321364060 User1 Micah 11/01/1969 Resume AJMLMOC.pdf
946497594 User2 Acker 05/28/1960 Transcript R4IKTRYN.pdf
887327716 User3 Aco 06/26/1950 Transcript R4IKTHMK.pdf
588496260 User4 John 05/23/1960 Letter R4IKTHSL.pdf
答案 1 :(得分:0)
给出了@IRon的答案,但是我找到了不需要单独脚本的解决方案,并认为我会将其发布以供将来参考。
$left = Import-Csv .\left.csv
$right = Import-Csv .\right.csv
$right | foreach {
$r = $_;
$left | where{ $_.First_Name -eq $r.First_Name -and $_.Last_Name -eq $r.Last_Name -and $_.DOB -eq $r.DOB } |
select Ref_Id,
First_Name,
Last_Name,
DOB,
@{Name="City";Expression={$r.City}},
@{Name="Document_Type";Expression={$r.Document_Type}},
@{Name="FileName";Expression={$r.FileName}}
} | format-table