Pandas で If-Else-Else 条件を使用した列を作成する
if-elif-else 条件に基づいて新しい列を作成するには2 つの主なアプローチがあります:
非ベクトル化アプローチ
このアプローチには、行を操作する関数の定義が含まれます:
def f(row):
if row['A'] == row['B']:
val = 0
elif row['A'] > row['B']:
val = 1
else:
val = -1
return val
次に、行に沿ってデータフレームに適用します:
df['C'] = df.apply(f, axis=1)
ベクトル化されたアプローチ
ベクトル化されたアプローチでは、np.where を利用して新しい列を直接作成します。
df['C'] = np.where(
df['A'] == df['B'], 0, np.where(
df['A'] > df['B'], 1, -1))
このアプローチは、大規模なデータセットの場合により効率的です。
提供されたデータフレームを使用した例を次に示します。
入力データフレーム
A | B |
---|---|
2 | 2 |
3 | 1 |
1 | 3 |
出力データフレーム
A | B | C |
---|---|---|
2 | 2 | 0 |
3 | 1 | 1 |
1 | 3 | -1 |
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3