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

Bibliothèques tierces Python Discussion :

Pandas left join multi critères


Sujet :

Bibliothèques tierces Python

  1. #1
    Membre à l'essai
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    décembre 2016
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Haute Garonne (Midi Pyrénées)

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

    Informations forums :
    Inscription : décembre 2016
    Messages : 17
    Points : 14
    Points
    14
    Par défaut Pandas left join multi critères
    Bonjour tout le monde,

    Voici mon problème de jointure:

    j'ai 2 dataframes (d'exemples):

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    df1 = pd.DataFrame({'Nom':['toto', 'titi', 'tutu'], 'Ville1':['NY', 'Chic', 'Paris'], 'Ville2':['N-Y', 'Chicago', 'Paries'], 'Ville3':['New-York', 'chicagooo', 'Pari']}) 
    df2 = pd.DataFrame({'Ville':['New-York', 'Chicago', 'Paris'], 'CP':['1', '2', '3']})
    Comment faire une jointure left join sur plusieurs conditions???
    Voici ce que j'aurais écrit en SQL:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    left join df2 on (df1.Ville1 = df2.Ville) or  (df1.Ville2 = df2.Ville) or (df1.Ville3 = df2.Ville)
    Une âme charitable pour me traduire ça en pandas?

    Merci beaucoup

  2. #2
    Membre éprouvé

    Homme Profil pro
    Ingénieur
    Inscrit en
    août 2010
    Messages
    539
    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 : 539
    Points : 903
    Points
    903
    Par défaut
    Salut,

    Quel est le résultat attendu? Est-ce un tableau avec les villes présentes à la fois dans ville, ville1, ville2 et ville3?

    Ju

  3. #3
    Membre à l'essai
    Homme Profil pro
    Ingénieur intégration
    Inscrit en
    décembre 2016
    Messages
    17
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 33
    Localisation : France, Haute Garonne (Midi Pyrénées)

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

    Informations forums :
    Inscription : décembre 2016
    Messages : 17
    Points : 14
    Points
    14
    Par défaut
    Salut

    Voici le résultat attendu:


    NOM CP
    toto 1
    titi 2
    tutu 3


    Merci pour l'aide !

  4. #4
    Membre éprouvé

    Homme Profil pro
    Ingénieur
    Inscrit en
    août 2010
    Messages
    539
    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 : 539
    Points : 903
    Points
    903
    Par défaut
    Salut,

    Je vois pas trop comment faire proprement. Du moins avec une commande magique de Pandas. On peut toujours créer un mapping entre la ville et le code postal. Un dictionnaire, issu de df2, avec en clés les villes et en valeur le CP. Créer une colonne à df1, nommée CP, avec une valeur par défaut. Pour chaque ligne du tableau df1, tester chaque ville en cherchant si elle se trouve dans le dictionnaire de mapping.

    C'est inefficace au possible cela dit.

    Ju

  5. #5
    Expert éminent Avatar de BufferBob
    Profil pro
    responsable R&D vidage de truites
    Inscrit en
    novembre 2010
    Messages
    2 832
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : responsable R&D vidage de truites

    Informations forums :
    Inscription : novembre 2010
    Messages : 2 832
    Points : 7 781
    Points
    7 781
    Par défaut
    salut,

    j'ai ce truc qui a l'air de fonctionner, à voir s'il y a plus concis/efficace :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    >>> df2.join(df1[(df1.Ville1 == df2.Ville) | (df1.Ville2 == df2.Ville) | (df1.Ville3 == df2.Ville)], how='left')[['Nom','CP']]
        Nom CP
    0  toto  1
    1  titi  2
    2  tutu  3
    Avant donc que d'écrire, apprenez à penser.
    Selon que notre idée est plus ou moins obscure, l'expression la suit, ou moins nette, ou plus pure.
    Ce que l'on conçoit bien s'énonce clairement, et les mots pour le dire arrivent aisément.
                                                        - Nicolas Boileau, L'Art poétique

Discussions similaires

  1. left join avec critère sur la table de droite
    Par rj450 dans le forum Langage SQL
    Réponses: 5
    Dernier message: 08/03/2019, 16h40
  2. Left Join Fetch + Critère
    Par Manopower dans le forum Hibernate
    Réponses: 4
    Dernier message: 30/12/2010, 16h47
  3. soucis de jointure sur plusieurs critères "left join ON . AND ON ."
    Par Moutonstar dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 24/11/2008, 17h22
  4. requête multi table left join
    Par G4uthier dans le forum Requêtes
    Réponses: 9
    Dernier message: 01/06/2008, 01h21
  5. probleme avec LEFT JOIN multi tables
    Par hinsano dans le forum Langage SQL
    Réponses: 5
    Dernier message: 08/07/2006, 06h36

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