Pandas dataframes'ı birden çok sütunda birleştirme
Çoğunlukla iki panda DataFrame’i birden fazla sütunda birleştirmek isteyebilirsiniz. Neyse ki, aşağıdaki sözdizimini kullanan pandas merge() işlevini kullanarak bunu yapmak kolaydır:
p.d. merge (df1, df2, left_on=['col1','col2'], right_on = ['col1','col2'])
Bu eğitimde bu fonksiyonun pratikte nasıl kullanılacağı açıklanmaktadır.
Örnek 1: Farklı adlara sahip birden çok sütunu birleştirme
Aşağıdaki iki panda DataFrame’e sahip olduğumuzu varsayalım:
import pandas as pd #create and view first DataFrame df1 = pd.DataFrame({'a1': [0, 0, 1, 1, 2], 'b': [0, 0, 1, 1, 1], 'c': [11, 8, 10, 6, 6]}) print (df1) a1 bc 0 0 0 11 1 0 0 8 2 1 1 10 3 1 1 6 4 2 1 6 #create and view second DataFrame df2 = pd.DataFrame({'a2': [0, 1, 1, 1, 3], 'b': [0, 0, 0, 1, 1], 'd': [22, 24, 25, 33, 37]}) print (df2) a2 comic 0 0 0 22 1 1 0 24 2 1 0 25 3 1 1 33 4 3 1 37
Aşağıdaki kod, her iki DataFrame’den birden çok sütun kullanarak sol birleştirmenin nasıl gerçekleştirileceğini gösterir:
p.d. merge (df1, df2, how=' left ', left_on=[' a1 ', ' b '], right_on = [' a2 ', ' b ']) a1 b c a2 d 0 0 0 11 0.0 22.0 1 0 0 8 0.0 22.0 2 1 1 10 1.0 33.0 3 1 1 6 1.0 33.0 4 2 1 6 NaN NaN
Örnek 2: Aynı adlara sahip birden çok sütunu birleştirme
Aynı sütun adlarına sahip aşağıdaki iki panda DataFrame’e sahip olduğumuzu varsayalım:
import pandas as pd #createDataFrames df1 = pd.DataFrame({'a': [0, 0, 1, 1, 2], 'b': [0, 0, 1, 1, 1], 'c': [11, 8, 10, 6, 6]}) df2 = pd.DataFrame({'a': [0, 1, 1, 1, 3], 'b': [0, 0, 0, 1, 1], 'd': [22, 24, 25, 33, 37]})
Bu durumda, sütun adları her iki DataFrame’de de aynı olduğundan on = [‘a’, ‘b’] kullanımını basitleştirebiliriz:
p.d. merge (df1, df2, how=' left ', on=[' a ', ' b ']) a b c d 0 0 0 11 22.0 1 0 0 8 22.0 2 1 1 10 33.0 3 1 1 6 33.0 4 2 1 6 NaN
Ek kaynaklar
Dizinde iki Pandas DataFrame nasıl birleştirilir
Birden fazla Pandas DataFrame’i nasıl istifleyebilirim?