> 백엔드 개발 > 파이썬 튜토리얼 > Python의 Pandas DataFrames에서 조건부 열 생성을 수행하는 방법은 무엇입니까?

Python의 Pandas DataFrames에서 조건부 열 생성을 수행하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-10-20 06:48:29
원래의
745명이 탐색했습니다.

How to Perform Conditional Column Creation in Python's Pandas DataFrames?

Python에서 조건부 논리를 기반으로 열 생성

Pandas DataFrames로 작업할 때 새로운 열을 생성해야 하는 시나리오에 자주 직면합니다. 기존 열 간의 조건부 확인을 기반으로 하는 열입니다. 이는 중첩된 조건과 함께 np.where 함수를 사용하여 달성할 수 있습니다.

설명하기 위해 다음 DataFrame을 고려하십시오.

<code class="python">import pandas as pd

df = pd.DataFrame({
    "A": [2, 3, 1],
    "B": [2, 1, 3]
})</code>
로그인 후 복사

다음 기준에 따라 새 열 C를 생성하려고 합니다. :

  • A가 B와 같으면 C는 0이어야 합니다.
  • A가 B보다 크면 C는 1이어야 합니다.
  • A가 B보다 작으면 , C는 -1이어야 합니다.

사용자 정의 함수 사용

한 가지 접근 방식은 조건부 논리를 구현하는 사용자 정의 함수를 생성하고 이를 DataFrame:

<code class="python">def f(row):
    if row['A'] == row['B']:
        return 0
    elif row['A'] > row['B']:
        return 1
    else:
        return -1

df['C'] = df.apply(f, axis=1)</code>
로그인 후 복사

np.where 사용

또는 np.where 함수를 사용하여 새 열에 값을 직접 할당할 수 있습니다.

<code class="python">df['C'] = np.where(df['A'] == df['B'], 0, np.where(df['A'] > df['B'], 1, -1))</code>
로그인 후 복사

이 접근 방식은 벡터화되어 대규모 데이터 세트에 더 효율적입니다.

결과:

두 접근 방식 모두 다음과 같은 결과를 생성합니다.

<code class="python">print(df)

   A  B  C
0  2  2  0
1  3  1  1
2  1  3 -1</code>
로그인 후 복사

위 내용은 Python의 Pandas DataFrames에서 조건부 열 생성을 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿