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édoublonnage tableau en gardant les plus grandes valeurs [PowerShell]


Sujet :

Scripts/Batch

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  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édoublonnage tableau en gardant les plus grandes valeurs
    Bonjour,

    J'ai ce tableau :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Path                         Users                 AccessRightFamilly
    ----                         -----                 ------------------
    \\SFRAxxxxx\partage\dossier DOMAIN\BERRIPIXC   3
    \\SFRAxxxxx\partage\dossier DOMAIN\monvodaviXC 3
    \\SFRAxxxxx\partage\dossier DOMAIN\fournpatrXC 3
    \\SFRAxxxxx\partage\dossier DOMAIN\guelldaviXC 2
    \\SFRAxxxxx\partage\dossier DOMAIN\berridaviXC 0
    \\SFRAxxxxx\partage\dossier DOMAIN\fouracarlXC 2
    \\SFRAxxxxx\partage\dossier DOMAIN\berruvaleXC 3
    \\SFRAxxxxx\partage\dossier DOMAIN\berruvaleXC 2
    \\SFRAxxxxx\partage\dossier DOMAIN\berramaleXC 3
    \\SFRAxxxxx\partage\dossier DOMAIN\fourqarnaXC 2
    \\SFRAxxxxx\partage\dossier DOMAIN\fourqarnaXC 3
    J'aimerai le dédoublonné en gardant les plus grande valeur dans la colonne "AccessRightFamilly"

    Comment dois-je procéder ?

    Je ne sais pas si un tri par rapport à la colonne "AccessRightFamilly" du plus grand au plus petit puis un dédoublonnage peut répondre à mon besoin.

    Merci d'avance

  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,
    Citation Envoyé par arnaudperfect Voir le message
    Je ne sais pas si un tri par rapport à la colonne "AccessRightFamilly" du plus grand au plus petit puis un dédoublonnage peut répondre à mon besoin.
    Le contrôle du résultat te le dira
    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
     
    $File='c:\temp\datas'
    @'
    Path;Users;AccessRightFamilly
    \\SFRAxxxxx\partage\dossier;DOMAIN\BERRIPIXC;3
    \\SFRAxxxxx\partage\dossier;DOMAIN\monvodaviXC;3
    \\SFRAxxxxx\partage\dossier;DOMAIN\fournpatrXC;3
    \\SFRAxxxxx\partage\dossier;DOMAIN\guelldaviXC;2
    \\SFRAxxxxx\partage\dossier;DOMAIN\berridaviXC;0
    \\SFRAxxxxx\partage\dossier;DOMAIN\fouracarlXC;2
    \\SFRAxxxxx\partage\dossier;DOMAIN\berruvaleXC;3
    \\SFRAxxxxx\partage\dossier;DOMAIN\berruvaleXC;2
    \\SFRAxxxxx\partage\dossier;DOMAIN\berramaleXC;3
    \\SFRAxxxxx\partage\dossier;DOMAIN\fourqarnaXC;2
    \\SFRAxxxxx\partage\dossier;DOMAIN\fourqarnaXC;3
    '@ > $File
     
    $T=import-csv $file -delimiter ';' 
    $g=$t|group users
    $result=$G|% {
     $current=$_.group    
     if ($current.Count -gt 1)
     { $Current|Sort AccessRightFamilly -Descending|select -first 1 }
     else 
     {  $Current  }
    }#for
    $result
     
    #contrôle du résultat
    #facilite la comparaison via un tableau de chaine, psobject -> String
    [String[]]$Tstr=$T
    [String[]]$Resultstr=$Result
     
    $set1 = New-Object System.Collections.Generic.HashSet[object](,$Tstr)
    $set1.ExceptWith($Resultstr)
    #liste des objets exclus
    $set1

  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
    Super, j'ai bien le résultat recherché.
    Je n'aurai pas pensé à ça comme algo.

    Je ne savais pas que % était un alias de foreach_object.

  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 n'aurai pas pensé à ça comme algo.
    Pour traiter les collections Group-Object est d'un usage récurrent, sans pour autant rendre le code 'avancé' ou dépendant d'une version/classe.
    Mais cela dépend de la volumétrie.
    Dans ce code je suppose que la clé est uniquement 'Users', vérifie pour ton contexte si ce sera tjr le cas.
    Citation Envoyé par arnaudperfect Voir le message
    Je ne savais pas que % était un alias de foreach_object.
    Il existe aussi le '?' pour Where-Object :
    ils sont en lecture seule.
    Code powershell : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    remove-item  alias:`?
    #remove-item : L'alias n'a pas été supprimé, car l'alias % est constant ou en lecture seule.

  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
    Que veux tu dires quand tu dis, ils sont en lecture seule ?

  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
    Que veux tu dires quand tu dis, ils sont en lecture seule ?
    C'est le runtime qui les déclare et les protège, on doit utiliser le paramètre -Force de Remove-Item pour les supprimer.

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 11/03/2015, 20h14
  2. Récupérer les plus grandes valeurs avec group by
    Par mysticpete dans le forum Doctrine2
    Réponses: 2
    Dernier message: 24/04/2013, 15h09
  3. les plus grand valeur et vecteur propre
    Par hanane78 dans le forum MATLAB
    Réponses: 4
    Dernier message: 22/02/2011, 11h50
  4. Réponses: 2
    Dernier message: 18/03/2009, 07h48
  5. Réponses: 11
    Dernier message: 22/03/2007, 16h45

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