Сравнение объектов массива друг с другом - PullRequest
0 голосов
/ 04 декабря 2018

У меня есть массив Powershell, который выглядит следующим образом:

TSMServer Cluster       VM       
--------- -------       --       
HTS01     APP-P02       Server9839
HTS01     APP-P13       Server3221
HTS01     APP-P13       Server3230
HTS05     APP-P12       Server3182
HTS05     APP-P12       Server9829
GTS05     APP-P06       Server0057
GTS05     APP-P06       Server0421
GTS05     APP-P06       Server2426
GTS05     APP-P06       Server0286
GTS05     APP-P06       Server0302
GTS05     APP-P07       Server0312
GTS05     APP-P12       Server2845
GTS05     APP-P12       Server3135
HTS01     APP-P10       Server1052
HTS05     APP-P12       Server3155
HTS05     APP-P12       Server3185
HTS05     APP-P12       Server9830
...

Мне нужно найти все виртуальные машины, имеющие одинаковые значения для TSMserver и Cluster.

Мне нужна команда для получения(например) эти 2 виртуальные машины, потому что они имеют одно и то же первое значение.

TSMServer Cluster       VM       
--------- -------       --   
HTS01     APP-P13       Server3221
HTS01     APP-P13       Server3230

Так что на самом деле мне нужно сравнить каждый объект в массиве с другими, чтобы найти общие значения для первых 2 свойств.

Большое СПАСИБО заранее!

Ответы [ 2 ]

0 голосов
/ 04 декабря 2018

Использовать Group-Object

$Servers = @"
TSMServer,Cluster,VM,
HTS01,APP-P02,Server9839
HTS01,APP-P13,Server3221
HTS01,APP-P13,Server3230
HTS05,APP-P12,Server3182
HTS05,APP-P12,Server9829
GTS05,APP-P06,Server0057
GTS05,APP-P06,Server0421
GTS05,APP-P06,Server2426
GTS05,APP-P06,Server0286
GTS05,APP-P06,Server0302
GTS05,APP-P07,Server0312
GTS05,APP-P12,Server2845
GTS05,APP-P12,Server3135
HTS01,APP-P10,Server1052
HTS05,APP-P12,Server3155
HTS05,APP-P12,Server3185
HTS05,APP-P12,Server9830
"@ | ConvertFrom-Csv 

$Servers | Sort-Object TSMServer,Cluster | Group-Object TSMServer,Cluster|
    ForEach-Object {
        $TSMServer,$Cluster = $_.Name -split ', '
        [PSCustomObject]@{
            TSMServer = $TSMServer
            Cluster   = $Cluster
            VMs       =($_.Group.VM | Sort-Object) -Join ','
        }
    }

Пример вывода:

TSMServer Cluster VMs
--------- ------- ---
GTS05     APP-P06 Server0057,Server0286,Server0302,Server0421,Server2426
GTS05     APP-P07 Server0312
GTS05     APP-P12 Server2845,Server3135
HTS01     APP-P02 Server9839
HTS01     APP-P10 Server1052
HTS01     APP-P13 Server3221,Server3230
HTS05     APP-P12 Server3155,Server3182,Server3185,Server9829,Server9830
0 голосов
/ 04 декабря 2018

Это можно сделать с помощью командлета Group-Object, например, так:
(переменная $ Servers здесь содержит массив объектов)

$servers | Group-Object -Property TSMServer, Cluster | Where-Object { $_.Count -gt 1 } | ForEach-Object {
   $_.Group | Format-Table -AutoSize
}

Дляприведенный пример массива объектов, выполнение приведенного выше приведет к:

TSMServer Cluster VM        
--------- ------- --        
HTS01     APP-P13 Server3221
HTS01     APP-P13 Server3230



TSMServer Cluster VM        
--------- ------- --        
HTS05     APP-P12 Server3182
HTS05     APP-P12 Server9829
HTS05     APP-P12 Server3155
HTS05     APP-P12 Server3185
HTS05     APP-P12 Server9830



TSMServer Cluster VM        
--------- ------- --        
GTS05     APP-P06 Server0057
GTS05     APP-P06 Server0421
GTS05     APP-P06 Server2426
GTS05     APP-P06 Server0286
GTS05     APP-P06 Server0302



TSMServer Cluster VM        
--------- ------- --        
GTS05     APP-P12 Server2845
GTS05     APP-P12 Server3135
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...