Verknüpfung einer Tabelle mit sich selbst

Daten mit pandas verknüpfen

Aaren Stubberfield

Instructor

Daten zu Fortsetzungsfilmen

print(sequel.head())
  id     title        sequel
0 19995  Avatar       NaN
1 862    Toy Story    863
2 863    Toy Story 2  10193
3 597    Titanic      NaN
4 24428  The Avengers NaN

Bild von Toy Story und der Fortsetzung Toy Story 2

Daten mit pandas verknüpfen

Verknüpfung einer Tabelle mit sich selbst

Bild von zwei Kopien derselben Tabelle, die zusammengefügt wurden

Daten mit pandas verknüpfen

Verknüpfung einer Tabelle mit sich selbst

original_sequels = sequels.merge(sequels, left_on='sequel', right_on='id', 
                                 suffixes=('_org','_seq'))
print(original_sequels.head())
  id_org  title_org        sequel_org  id_seq  title_seq        sequel_seq
0 862     Toy Story        863         863     Toy Story 2      10193     
1 863     Toy Story 2      10193       10193   Toy Story 3      NaN       
2 675     Harry Potter...  767         767     Harry Potter...  NaN       
3 121     The Lord of ...  122         122     The Lord of ...  NaN       
4 120     The Lord of ...  121         121     The Lord of ...  122
Daten mit pandas verknüpfen

Ergebnisse: Original und Fortsetzung

print(original_sequels[,['title_org','title_seq']].head())
  title_org        title_seq      
0 Toy Story        Toy Story 2    
1 Toy Story 2      Toy Story 3    
2 Harry Potter...  Harry Potter...
3 The Lord of ...  The Lord of ...
4 The Lord of ...  The Lord of ...
Daten mit pandas verknüpfen

Tabelle mit linksseitigem Join mit sich selbst verknüpfen

original_sequels = sequels.merge(sequels, left_on='sequel', right_on='id', 
                                 how='left', suffixes=('_org','_seq'))
print(original_sequels.head())
  id_org  title_org     sequel_org  id_seq  title_seq    sequel_seq
0 19995   Avatar        NaN         NaN     NaN          NaN       
1 862     Toy Story     863         863     Toy Story 2  10193     
2 863     Toy Story 2   10193       10193   Toy Story 3  NaN       
3 597     Titanic       NaN         NaN     NaN          NaN       
4 24428   The Avengers  NaN         NaN     NaN          NaN
Daten mit pandas verknüpfen

Wann Tabelle mit sich selbst verknüpfen?

Häufige Situationen:

  • Hierarchische Beziehungen
  • Sequentielle Beziehungen
  • Diagramme
Daten mit pandas verknüpfen

Lass uns üben!

Daten mit pandas verknüpfen

Preparing Video For Download...