Pandas에서 If-Else-Else 조건을 사용하여 열 생성
if-elif-else 조건을 기반으로 새 열을 생성하려면 에는 두 가지 주요 접근 방식이 있습니다.
비벡터화 접근 방식
이 접근 방식에는 행에서 작동하는 함수 정의가 포함됩니다.
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