2017-08-09 73 views
3

我在PowerShell來陣列的對象。每個數組都包含一個對象數組。這些對象有兩個屬性:如何找到,如果Powershell的Array包含其他陣列

名稱:字符串
編號:GUID

第一陣列中有4413點的對象,第二個4405的計數是無關緊要的,但我只提到它們要注意的是Array1和Array2的內容是不同的。

這裏是我當前的代碼(僞):

#Fill Array1 
$Array1 = Fill-Array1 

#Fill Array2 
$Array2 = Fill-Array2 

#Loop through the arrays and write out the names of all items in Array2 that are different than Array1 
ForEach($Val in $Array2) 
{ 
    $Name = $Val.Name 

    If($Array1 -notcontains $Val) //this does not work 
    { 
     Write-Host $Name 
    } 
} 

什麼是您在數組1對象存在的正確方法是什麼?我唯一的選擇是做一個嵌套循環嗎?

更新,使用從下面Manu P答案,以下是我是如何實現的解決方案:

#Fill Array1 
    $Array1 = Fill-Array1 

    #Fill Array2 
    $Array2 = Fill-Array2 

    #Compare the arrays 
    $ComparedResults = Compare-Object -ReferenceObject $Array1 -DifferenceObject $Array2 #I left out the -IncludeEqual param because I don't care about those results 

    ForEach($Result in $ComparedResults) 
    { 
     If($Result.SideIndicator -eq "=>") #the value in Array2 is different than Array1 
     { 
      $Val = $Result.InputObject 

      Write-Host $Val.Name    
     }   
    } 
+1

當我使用2個陣列與他們只是一些隨機數此完全相同的方法,它完美的作品。也許它與數組中的對象類型有關? – cet51

+2

@CoryEtmund谷歌「參考平等VS價值平等」 :-) –

回答

1

由於GUID是可比的,你可以簡單的(內部)使用此處描述的功能加入陣列:https://stackoverflow.com/a/45483110/1701026

$Array1 = @(
    [pscustomobject]@{Name = "a"; Id = [guid]::NewGuid()} 
    [pscustomobject]@{Name = "b"; Id = [guid]::NewGuid()} 
    [pscustomobject]@{Name = "c"; Id = [guid]"de5e32c6-5338-4287-8c21-2dd5957cfffe"} 
    [pscustomobject]@{Name = "d"; Id = [guid]"345f9ac2-86a0-4b01-b843-5f4bd55f5e21"} 
    [pscustomobject]@{Name = "e"; Id = [guid]"953c1442-ed51-445e-a8f5-687120d98f83"} 
    [pscustomobject]@{Name = "f"; Id = [guid]::NewGuid()} 
) 

$Array2 = @(
    [pscustomobject]@{Name = "b"; Id = [guid]::NewGuid()} 
    [pscustomobject]@{Name = "c"; Id = [guid]"345f9ac2-86a0-4b01-b843-5f4bd55f5e21"} 
    [pscustomobject]@{Name = "d"; Id = [guid]"345f9ac2-86a0-4b01-b843-5f4bd55f5e21"} 
    [pscustomobject]@{Name = "e"; Id = [guid]"953c1442-ed51-445e-a8f5-687120d98f83"} 
    [pscustomobject]@{Name = "f"; Id = [guid]"953c1442-ed51-445e-a8f5-687120d98f83"} 
    [pscustomobject]@{Name = "g"; Id = [guid]::NewGuid()} 
) 

$Array1 | InnerJoin $Array2 -Using Name,Id | Format-Table 

結果:

Id         Name 
--         ---- 
345f9ac2-86a0-4b01-b843-5f4bd55f5e21 d 
953c1442-ed51-445e-a8f5-687120d98f83 e 

要獲得所有記錄具有相同的名稱,其中編號爲不等於:

$Array1 | InnerJoin $Array2 -on {$Left.Name -eq $Right.Name -and $Left.Id -ne $Right.Id} -Merge @{Name = {$Left.$_}} | Format-Table 

結果:

Id                   Name 
--                   ---- 
{3b175777-e88f-4248-965b-51dec8639fd6, a43d68de-9ed5-4a13-8f8e-61c6cc501458} b 
{de5e32c6-5338-4287-8c21-2dd5957cfffe, 345f9ac2-86a0-4b01-b843-5f4bd55f5e21} c 
{2a8c4bf7-cf3a-4c3d-b27b-ecb6f4a4fa43, 953c1442-ed51-445e-a8f5-687120d98f83} f 
+0

這是一個非常不錯的主意,但它給我的等值時,我想的是不同的。 – crackedcornjimmy