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

Python Discussion :

Extraire la plus importante valeur d'un groupe sans remplacement


Sujet :

Python

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Analyse système
    Inscrit en
    Juin 2018
    Messages
    180
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Aveyron (Midi Pyrénées)

    Informations professionnelles :
    Activité : Analyse système
    Secteur : Alimentation

    Informations forums :
    Inscription : Juin 2018
    Messages : 180
    Par défaut Extraire la plus importante valeur d'un groupe sans remplacement
    Bonjour,

    Je dispose d'un dataframe qui représente différentes combinaisons de personnes (11 personnes au total), avec un score par combinaison allant de 0 (mauvais) à 20 (très bon) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    nom_combinaison; personnes; score_combinaison_sur_20
    combi1           personne1      18
    combi1           personne2      18
    combi2           personne2      4
    combi2           personne3      4
    combi3           personne1      14
    combi3           personne3      14
    ...       ; ...
    Je souhaiterais trouver un moyen d'extraire les combinaisons qui possèdent le meilleur score tout en faisant attention de ne pas prendre plusieurs fois la même personne. J'ai essayé plusieurs méthodes avec des recherches sur internet, malheureusement sans résultat. Est-il possible de faire cela ?

    Merci.

  2. #2
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 738
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 738
    Par défaut
    Salut,

    Citation Envoyé par preliator Voir le message
    J'ai essayé plusieurs méthodes avec des recherches sur internet, malheureusement sans résultat. Est-il possible de faire cela ?
    Le forum algorithmes est là pour essayer répondre à ce genre de question.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Membre émérite

    Homme Profil pro
    Ingénieur
    Inscrit en
    Août 2010
    Messages
    662
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2010
    Messages : 662
    Par défaut
    Salut,

    Dans l'exemple que vous donnez, quel est le résultat attendu ? Le meilleur résultat de combi1 est 18, mais c'est aussi le score de toutes les personnes de cette combinaison. Est-ce à dire que dès lors qu'une personne est choisie, elle ne peut plus l'être ? Dans ce cas on aurait le résultat suivant :
    • combi1 : 18 (personne1)
    • combi2 : 4 (personne2)
    • combi3 : 14 (personne3)


    J

  4. #4
    Expert confirmé
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 486
    Billets dans le blog
    6
    Par défaut
    Bonjour,

    Sur le principe, voilà comment je ferais:

    - placer les données dans une liste de listes comme:

    [['combi1', 'personne1', 18], ['combi1', 'personne2', 18], ... ]

    - trier la liste selon le dernier élément des sous-listes (=le score) dans le sens du plus grand au plus petit.

    - créer une liste qui contiendra les personnes enregistrées pour éviter de citer plusieurs fois la même

    - faire une boucle et enregistrer les combinaisons si la personne n'a jamais été citée. Si ok, enregistrer la personne dans la liste précédente

    Je n'ai pas Python sous la main, mais ça devrait marcher comme ça.

  5. #5
    Expert confirmé
    Avatar de tyrtamos
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2007
    Messages
    4 486
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Retraité

    Informations forums :
    Inscription : Décembre 2007
    Messages : 4 486
    Billets dans le blog
    6
    Par défaut
    Voilà un petit code conforme à ce que j'ai compris:

    Code : 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
    # liste d'origine
    L = [['combi1', 'personne1', 18],
         ['combi1', 'personne2', 18],
         ['combi2', 'personne2', 4],
         ['combi2', 'personne3', 4],
         ['combi3', 'personne1', 14],
         ['combi3', 'personne3', 14]]
     
    # liste triée selon le score (du plus grand au plus petit)
    L.sort(key=lambda v: v[2], reverse=True)
     
    # affichage des combinaisons en fonction des scores
    C = []
    for elem in L:
        if elem[1] not in C:
            print(elem)
            C.append(elem[1]) # enregistrement de la personne
    Résultat:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    ['combi1', 'personne1', 18]
    ['combi1', 'personne2', 18]
    ['combi3', 'personne3', 14]

  6. #6
    Membre confirmé
    Homme Profil pro
    Analyse système
    Inscrit en
    Juin 2018
    Messages
    180
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 30
    Localisation : France, Aveyron (Midi Pyrénées)

    Informations professionnelles :
    Activité : Analyse système
    Secteur : Alimentation

    Informations forums :
    Inscription : Juin 2018
    Messages : 180
    Par défaut
    Citation Envoyé par tyrtamos Voir le message
    Voilà un petit code conforme à ce que j'ai compris:

    Code : 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
    # liste d'origine
    L = [['combi1', 'personne1', 18],
         ['combi1', 'personne2', 18],
         ['combi2', 'personne2', 4],
         ['combi2', 'personne3', 4],
         ['combi3', 'personne1', 14],
         ['combi3', 'personne3', 14]]
     
    # liste triée selon le score (du plus grand au plus petit)
    L.sort(key=lambda v: v[2], reverse=True)
     
    # affichage des combinaisons en fonction des scores
    C = []
    for elem in L:
        if elem[1] not in C:
            print(elem)
            C.append(elem[1]) # enregistrement de la personne
    Résultat:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    ['combi1', 'personne1', 18]
    ['combi1', 'personne2', 18]
    ['combi3', 'personne3', 14]
    Un grand merci pour votre aide cela répond bien à ma question

  7. #7
    Membre prolifique
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 830
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 830
    Billets dans le blog
    1
    Par défaut
    Bonjour
    Citation Envoyé par preliator Voir le message
    Je souhaiterais trouver un moyen d'extraire les combinaisons qui possèdent le meilleur score tout en faisant attention de ne pas prendre plusieurs fois la même personne.
    Et que fais-tu si une combinaison possède deux personnes ayant le meilleur score (ex combi1 qui a 18 atteint par personne1 et personne2) ?

    Citation Envoyé par preliator Voir le message
    J'ai essayé plusieurs méthodes avec des recherches sur internet, malheureusement sans résultat.
    Un peu normal. Sur internet (outil communautaire et non lampe magique de Shazam) tu trouveras des trucs très généralistes (ex comment concaténer des dictionnaires), ou des trucs archi connus de par leurs valeurs d'exemples (tours de Hanoï, pendu, ...). Tu ne trouveras jamais le "comment ranger ma petite liste que je suis le seul à utiliser".

    Citation Envoyé par preliator Voir le message
    Est-il possible de faire cela ?
    Oui. Si tu peux le faire avec un papier/crayon tu peux le faire faire par Python. Peux-tu le faire avec un papier/crayon ?
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

Discussions similaires

  1. Réponses: 2
    Dernier message: 24/07/2013, 14h57
  2. [XL-2003] Extraire les 10 plus grandes valeurs après filtrage
    Par thojus dans le forum Excel
    Réponses: 9
    Dernier message: 05/03/2013, 17h09
  3. extraire 5 plus grande valeur d'un tableau
    Par redstoff dans le forum Macros et VBA Excel
    Réponses: 2
    Dernier message: 05/12/2011, 11h50
  4. Plus petite valeur, sous groupe
    Par martinfa dans le forum Requêtes
    Réponses: 4
    Dernier message: 04/02/2011, 19h06
  5. Réponses: 4
    Dernier message: 12/04/2008, 12h42

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