ホームページ >バックエンド開発 >Python チュートリアル >Pandas でインデックスによって DataFrame をマージするにはどうすればよいですか?また、利用可能なマージにはどのような種類がありますか?
インデックスによる DataFrame のマージ: 総合ガイド
インデックスに基づいて 2 つの DataFrame をマージすることは、一般的なデータ操作タスクです。ただし、マージが正しく行われないと、エラーや予期しない動作が発生する可能性があります。このガイドでは、インデックスによるマージのさまざまな方法を詳しく説明し、その主な違いと潜在的な落とし穴に焦点を当てます。
マージ関数について
Python の Pandas ライブラリでは、 DataFrame のマージには、merge、join、concat などのいくつかの関数を使用できます。各関数には独自のデフォルトの結合タイプがあります。
インデックスによるマージ
インデックスによって 2 つの DataFrame をマージするには、left_index パラメーターと right_index パラメーターを指定する必要があります。マージまたは結合関数で。これは、DataFrame の行ラベル (インデックス) を結合キーとして使用するように Pandas に指示します。
例:
次の 2 つの DataFrame について考えます:
<code class="python">df1 = pd.DataFrame({'a': range(6), 'b': [5, 3, 6, 9, 2, 4]}, index=list('abcdef')) df2 = pd.DataFrame({'c': range(4), 'd': [10, 20, 30, 40]}, index=list('abhi'))</code>
内部結合 (デフォルト):
マージ関数を使用して内部結合を実行するには:
<code class="python">pd.merge(df1, df2, left_index=True, right_index=True)</code>
出力:
a b c d a 0 5 0 10 b 1 3 1 20
左結合 (デフォルト):
結合関数を使用して左結合を実行するには:
<code class="python">df1.join(df2)</code>
出力:
a b c d a 0 5 0.0 10.0 b 1 3 1.0 20.0 c 2 6 NaN NaN d 3 9 NaN NaN e 4 2 NaN NaN f 5 4 NaN NaN
外部結合:
concat 関数を使用して外部結合を実行するには:
<code class="python">pd.concat([df1, df2], axis=1)</code>
出力:
a b c d a 0.0 5.0 0.0 10.0 b 1.0 3.0 1.0 20.0 c 2.0 6.0 NaN NaN d 3.0 9.0 NaN NaN e 4.0 2.0 NaN NaN f 5.0 4.0 NaN NaN h NaN NaN 2.0 30.0 i NaN NaN 3.0 40.0
重要な注意事項:
以上がPandas でインデックスによって DataFrame をマージするにはどうすればよいですか?また、利用可能なマージにはどのような種類がありますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。