IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Scripts/Batch Discussion :

Dédoublonner un objet de type PSObject [PowerShell]


Sujet :

Scripts/Batch

  1. #1
    Membre éprouvé
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Décembre 2006
    Messages
    1 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 080
    Par défaut Dédoublonner un objet de type PSObject
    Bonjour,

    En powershell, j'ai un objet de type PSObject.

    Il y a des lignes en doublon. Est-il possible de les dédoublonnées ? Si oui comment ?

    J'ai essayé Select-Object -Unique sans succès (ca me donne pas le résultat attendu, il me retourne une seule ligne sur les 700)

    Merci pour vos lumières

  2. #2
    Rédacteur


    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    7 171
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2003
    Messages : 7 171
    Billets dans le blog
    1
    Par défaut
    Salut,
    je ne comprends pas ta question .
    Est-ce que tu manipules les membres d'un objet ou des lignes de texte ?
    Un exemple ne serait pas de trop ...

  3. #3
    Membre éprouvé
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Décembre 2006
    Messages
    1 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 080
    Par défaut
    En faite, je fais ça :

    Code powershell : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    Function ComparaisonListeServeurAvecAuditNetBackup{
    	Param(
    		[parameter(Mandatory=$true)][object]$ListServeurs,
    		[parameter(Mandatory=$true)][object]$AuditNetBackup
    	)
    	Foreach($ListServeur in $ListServeurs) {
     
    		Foreach($Item in $AuditNetBackup){
     
    			If($ListServeur.Serveurs -eq $Item.ServeurConfigServeurs){
    				# Affichage des résultats
    				New-Object -TypeName PSObject -Property @{	Serveur = $ListServeur.Serveurs
    															ServeurNetBackup = $Item.ServeurConfigServeurs
    															VersionNB = $Item.ServeurConfigVersionNB
    															NBClientPlatform = $Item.ServeurConfigNBClientPlatform
    															ClientOS = $Item.ServeurConfigClientOS
    															NamePolicy = $Item.ServeurByPolicyNamePolicy
    															PolicyIsActive = $Item.ScheduleByPolicyAndStatutPolicyIsActive
    															NameSchedule = $Item.ScheduleByPolicyAndStatutNameSchedule
    														} | Select Serveur,ServeurNetBackup,VersionNB,NBClientPlatform,ClientOS,NamePolicy,PolicyIsActive,NameSchedule
    			}else{
    			# Affichage des résultats
    				New-Object -TypeName PSObject -Property @{	Serveur = $ListServeur.Serveurs
    															ServeurNetBackup = "-"
    															VersionNB = "-"
    															NBClientPlatform = "-"
    															ClientOS = "-"
    															NamePolicy = "-"
    															PolicyIsActive = "-"
    															NameSchedule = "-"
    														} | Select Serveur,ServeurNetBackup,VersionNB,NBClientPlatform,ClientOS,NamePolicy,PolicyIsActive,NameSchedule
    			}
    		}
    	}
    }
     
    ######################################
    #                MAIN                #
    ######################################
    CLS
    $PathBinNetBackup = "D:\Program Files\VERITAS\NetBackup\bin\admincmd"
    $ListServeurs = Import-Csv -Path "D:\test\Serveurs.csv"
     
    $AuditNetBackup = AuditNetBackup -PathBinNetBackup $PathBinNetBackup
     
    ComparaisonListeServeurAvecAuditNetBackup -ListServeurs $ListServeurs -AuditNetBackup $AuditNetBackup

    Je compare une liste avec une autre. Cependant, même si je ne trouve pas d’occurrence, je souhaite l'afficher dans le retour final (PSObject) d'où le :

    Code powershell : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    If($ListServeur.Serveurs -eq $Item.ServeurConfigServeurs){
    ...
    }else{
    ...
    }

    Les doublons sont donnés par le else, ce qui est normal, mais j'aimerai les filtrés lorsque j’appelle ma fonction "ComparaisonListeServeurAvecAuditNetBackup"

    Après, peut être que je peux le filtré directement dans la fonction, ce qui serait plus optimisé.

  4. #4
    Rédacteur


    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    7 171
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2003
    Messages : 7 171
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par arnaudperfect Voir le message
    Je compare une liste avec une autre. Cependant, même si je ne trouve pas d’occurrence, je souhaite l'afficher dans le retour final (PSObject) d'où le :
    Ne connaissant ni les données, ni le contexte je ne sais pas si ma proposition est pertinente.
    Ceci dit, pourquoi ne pas utiliser Compare-Object puis créer un objet seulement s'il existe une occurrence ?
    Sinon laisse en l'état, tout en supprimant le select-object inutile, et utilise group-object avec une propriété calculée, par exemple : ServeurNetBackup -ne '-'
    Pourquoi ne pas utiliser $null au lieu de "-" ?

  5. #5
    Membre éprouvé
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Décembre 2006
    Messages
    1 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 080
    Par défaut
    Faire quelque chose comme ça ?

    Code powershell : Sélectionner tout - Visualiser dans une fenêtre à part
    ComparaisonListeServeurAvecAuditNetBackup -ListServeurs $ListServeurs -AuditNetBackup $AuditNetBackup | Sort-Object -Property $_.ServeurNetBackup | Group-Object -Property ($_.ServeurNetBackup -ne $null)

  6. #6
    Rédacteur


    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    7 171
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2003
    Messages : 7 171
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par arnaudperfect Voir le message
    Faire quelque chose comme ça ?
    Je pensais à qq chose comme cela :
    Code powershell : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
     
      #compare deux listes de process
    $p=get-process
    &notepad;&notepad    
    $p2=get-process  #supprimer les 2 notepad
     
    #ne récupère que les infos de comparaison, l'objet initial est 'perdu'
    Compare-Object $P $p2 -Property "Name" -IncludeEqual|
       Where-Object {$_."SideIndicator" -eq "=>"}
     
    #Récupère les infos de comparaison et l'objet initial, PS ajout un membre dynamique 'SideIndicator'
    Compare-Object $P $p2 -Property "Name" -IncludeEqual -PassThru | 
       Where-Object {$_."SideIndicator" -eq "=>"}
     
     
    $compare = Compare-Object $P $P2 -Property "name" -PassThru | 
                  Where-Object {$_."SideIndicator" -eq "=>"}
     
    #Tri selon l'état
    $Egaux =@()
    $Inexistants =@()
    $Nouveaux =@()
    foreach ($Item in (Compare-Object $P $p2 -Property "Name" -IncludeEqual -PassThru))
    {
     switch ($Item.SideIndicator) 
     {
      '==' {$Egaux +=$item}
      '<=' {$Inexistants +=$item}
      '=>' {$Nouveaux +=$item}
     }
    }
     
    $Egaux
    $Inexistants
    $Nouveaux

  7. #7
    Membre éprouvé
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Décembre 2006
    Messages
    1 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 080
    Par défaut
    Le problème c'est que dans mon objet $ListServeurs, j'ai une liste de serveur.

    Exemple :
    ListeServeurs
    SRV001
    SRV002
    SRV003
    SRV005
    Dans l'objet $AuditNetBackup, j'ai une liste de serveur avec des informations concernant un audit sur le logiciel de sauvegarde Netbackup

    Exemple :
    ServeursNetBackup;VersionClient;Policy,Schedule
    SRV001;1.0;Policy_1;Schedule1
    SRV002;1.0;Policy_5;Schedule3
    SRV003;1.0;Policy_7;Schedule7
    SRV003;1.0;Policy_8;Schedule9
    SRV004";1.0;Policy_7;Schedule7
    Je veux comparer ces deux objets pour mettre en évidence les serveurs qui possèdent une configuration sur Netbackup (relever par mon audit préalable), mais aussi, si cela ne match pas, l'indiqué dans le rapport final.

    La clef de correspondance est ListeServeurs = Serveurs

    ListeServeurs;Serveurs;VersionClient;Policy,Schedule
    SRV001;SRV001;1.0;Policy_1;Schedule1
    SRV002;SRV002;1.0;Policy_5;Schedule3
    SRV003;SRV003;1.0;Policy_7;Schedule7
    SRV003;SRV003;1.0;Policy_8;Schedule9
    SRV005;$null;$null;$null;$null
    Dans mon script, j'arrive à affiché les correspondances qui match. Mais celle qui ne match pas, me fait des doublons (et cela est normal vu que j'ai une boucle imbriqué dans une autre). Mais j'aimerai éviter cela.

    Dans ton exemple, je ne pense pas que cela peut fonctionner, car tes deux objets possède les même entêtes. Dans mon cas cela n'est pas le cas.

  8. #8
    Rédacteur


    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    7 171
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2003
    Messages : 7 171
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par arnaudperfect Voir le message
    Dans ton exemple, je ne pense pas que cela peut fonctionner, car tes deux objets possède les même entêtes. Dans mon cas cela n'est pas le cas.
    Dans cas on s'adapte :
    Code powershell : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
     
     
    $ListeServeurs='SRV001','SRV002','SRV003','SRV005'|
     Foreach-Object { 
      New-Object PsObject -Property @{Serveur=$_}
    } 
     
    $AuditNetBackup=@'
    ServeursNetBackup;VersionClient;Policy;Schedule
    SRV001;1.0;Policy_1;Schedule1
    SRV002;1.0;Policy_5;Schedule3
    SRV003;1.0;Policy_7;Schedule7
    SRV003;1.0;Policy_8;Schedule9
    SRV004;1.0;Policy_7;Schedule7
    '@ | ConvertFrom-Csv -Delimiter ';'
    #Pas la bonne structure ( nom de propriété )? On la transforme
    $AuditServeurs=$AuditNetBackup|Select @{N='Serveur';e={$_.ServeursNetBackup}},VersionClient,Policy,Schedule 
     
     
    $Egaux =@()
    $Inexistants =@()
    $Nouveaux =@()
     
    # -ReferenceObject renvoi l'objet d'origine, à savoir $AuditServeurs transformé à partir de $AuditNetBackup 
    foreach ($Item in (Compare-Object -ReferenceObject $AuditServeurs -DifferenceObject $ListeServeurs  -Property 'Serveur' -IncludeEqual -PassThru))
    {
     switch ($Item.SideIndicator) 
     {
      '==' {$Egaux +=$item}
      '<=' {$Inexistants +=$item}
      '=>' {$Nouveaux +=$item}
     }
    }
     
     #Contient des objets issus de la liste $AuditServeurs 
    $Egaux
     
    #Contient des objets issus de la liste $AuditServeurs
     #Attention aux doublons : SRV003
     $Inexistants
     
     #Contient des objets issus de la liste $ListeServeurs
     #SRV005
     #ICI modifier la structure
     
    $Nouveaux
     
    $News=@($Nouveaux|Select 'Serveur',VersionClient,Policy,Schedule)
    $News[0]
    # Serveur                       VersionClient                 Policy
    # -------                       -------------                 ------
    # SRV005
     
    $News[0].VersionClient -eq $null
    #True
    Il reste peut être un pb avec les doublons...

  9. #9
    Rédacteur


    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    7 171
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2003
    Messages : 7 171
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par Laurent Dardenne Voir le message
    Il reste peut être un pb avec les doublons...
    La propriété SideIndicator est trompeuse, il suffit de combiner les noms de serveur trouvés et leur doublons :
    Code powershell : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
     
    $Existants=$Egaux+$Inexistants
    $News=@($Nouveaux|Select Serveur,VersionClient,Policy,Schedule)
     
    $All=@(
     $Existants
     $News
    )
    $All|Select * -ExcludeProperty SideIndicator
    # 
    # Serveur                       VersionClient                 Policy                        Schedule
    # -------                       -------------                 ------                        --------
    # SRV001                        1.0                           Policy_1                      Schedule1
    # SRV002                        1.0                           Policy_5                      Schedule3
    # SRV003                        1.0                           Policy_7                      Schedule7
    # SRV003                        1.0                           Policy_8                      Schedule9
    # SRV004                        1.0                           Policy_7                      Schedule7
    # SRV005
    On peut aussi simplifier le switch, c+ mieux

  10. #10
    Membre éprouvé
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Décembre 2006
    Messages
    1 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 080
    Par défaut
    Merci pour ce retour. J'ai étudié ta proposition.

    J'ai fais quelques tests, et complété le jeu de test.

    Code powershell : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    $ListeServeurs='SRV001','SRV002','SRV003','SRV004'|
     Foreach-Object { 
      New-Object PsObject -Property @{Serveur=$_}
    } 
     
    $AuditNetBackup=@'
    ServeursNetBackup;VersionClient;Policy;Schedule
    SRV002;1.0;Policy_1;Schedule1
    SRV004;1.0;Policy_5;Schedule3
    SRV005;1.0;Policy_7;Schedule7
    SRV001;1.0;Policy_8;Schedule9
    SRV006;1.0;Policy_8;Schedule9
    SRV004;1.0;Policy_7;Schedule7
    SRV001;1.0;Policy_5;Schedule2
    '@ | ConvertFrom-Csv -Delimiter ';'
    #Pas la bonne structure ( nom de propriété )? On la transforme
    $AuditServeurs=$AuditNetBackup|Select @{N='Serveur';e={$_.ServeursNetBackup}},VersionClient,Policy,Schedule 
     
    $Egaux =@()
    $Inexistants =@()
    $Nouveaux =@()
     
    # -ReferenceObject renvoi l'objet d'origine, à savoir $AuditServeurs transformé à partir de $AuditNetBackup 
    foreach ($Item in (Compare-Object -ReferenceObject $AuditServeurs -DifferenceObject $ListeServeurs  -Property 'Serveur' -IncludeEqual -PassThru))
    {
     switch ($Item.SideIndicator) 
     {
      '==' {$Egaux +=$item}
      '<=' {$Inexistants +=$item}
      '=>' {$Nouveaux +=$item}
     }
    }
     
     #Contient des objets issus de la liste $AuditServeurs 
    #$Egaux
     
    #Contient des objets issus de la liste $AuditServeurs
     #Attention aux doublons : SRV003
     $Inexistants

    Je test chaque variable pour comprendre le mécanisme et sur $Inexistants j'ai ce retour :

    Serveur : SRV005
    VersionClient : 1.0
    Policy : Policy_7
    Schedule : Schedule7
    SideIndicator : <=

    Serveur : SRV006
    VersionClient : 1.0
    Policy : Policy_8
    Schedule : Schedule9
    SideIndicator : <=

    Serveur : SRV004
    VersionClient : 1.0
    Policy : Policy_7
    Schedule : Schedule7
    SideIndicator : <=

    Serveur : SRV001
    VersionClient : 1.0
    Policy : Policy_5
    Schedule : Schedule2
    SideIndicator : <=
    Le script nous retourne SRV004 et SRV001 comme étant absent de la liste $ListeServeurs. Cela se produit car dans la liste $AuditServeurs j'ai deux fois SRV004 et SRV001, mais avec des informations différentes. Ont peut faire comment pour remédier à ce faux problème ?

  11. #11
    Rédacteur


    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    7 171
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2003
    Messages : 7 171
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par arnaudperfect Voir le message
    On peut faire comment pour remédier à ce faux problème ?
    Consulte mon dernier post.

  12. #12
    Membre éprouvé
    Homme Profil pro
    Ingénieur systèmes et réseaux
    Inscrit en
    Décembre 2006
    Messages
    1 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : Ingénieur systèmes et réseaux

    Informations forums :
    Inscription : Décembre 2006
    Messages : 1 080
    Par défaut
    Effectivement, cela fonctionne bien !

    Je vais le testé avec mes données !

    Encore un grand merci, de plus j'ai appris de nouvelle chose.

  13. #13
    Rédacteur


    Profil pro
    Inscrit en
    Janvier 2003
    Messages
    7 171
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2003
    Messages : 7 171
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par arnaudperfect Voir le message
    Encore un grand merci, de plus j'ai appris de nouvelle chose.
    Il ne faut pas hésiter à étudier l'usage des cmdlets dédiés aux objects :
    Code powershell : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    Get-Command -Noun Object
    Les traitement des données avec PS étant souvent similaires, leurs implémentation l'est également .

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [Debutant][Conception] visibilité des objets de type conteneur
    Par thebloodyman dans le forum Général Java
    Réponses: 10
    Dernier message: 04/01/2006, 12h44
  2. Réponses: 3
    Dernier message: 28/10/2005, 01h12
  3. Tableau d'objets de type différents
    Par Hell dans le forum C++
    Réponses: 9
    Dernier message: 11/01/2005, 22h57
  4. [Sérialisation] d'objets de types différents
    Par Amnesiak dans le forum Général Java
    Réponses: 3
    Dernier message: 08/12/2004, 22h28
  5. DB objet sous types heritage
    Par smex dans le forum Décisions SGBD
    Réponses: 2
    Dernier message: 15/06/2004, 21h58

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo