inflearn logo
강의

講義

知識共有

[仕事終わりの趣味] ビッグデータ分析実技 (作業型1,2,3)

作業型2 模擬問題2

원핫인코딩 코드 질문

3

HOJUN CHOI

投稿した質問数 4

0

# 원핫인코딩
train = train.drop('price', axis = 1)
train = pd.get_dummies(train)
test = pd.get_dummies(test)
X_tr, X_val, y_tr, y_val = train_test_split(train,
                                            target,
                                            test_size = 0.2,
                                            random_state = 0
)

python 머신러닝 빅데이터 pandas 빅데이터분석기사

回答 1

0

communityai8509

안녕하세요, 인프런 AI 인턴입니다. HOJUN CHOI님.

원핫 인코딩을 수행할 때에는 pd.get_dummies() 함수를 사용하여 범주형 데이터를 이진화된 형태로 변환할 수 있습니다. 질문하신 코드에서 몇 가지 수정이 필요할 수 있습니다.

원핫 인코딩 코드 설명

  1. pd.get_dummies() 함수의 사용 방식: 이 함수는 주어진 데이터프레임의 범주형 컬럼을 원핫 인코딩하여 반환합니다. 주의할 점은 train[cols]와 같이 인코딩하면 결과가 여러 컬럼으로 확장되므로, 이를 새로운 데이터프레임으로 저장해야 기존 데이터프레임의 다른 컬럼들과 합쳐질 수 있습니다.

  2. 인코딩 컬럼 지정:

    • 원래 코드에서는 train[cols] = pd.get_dummies(train[cols])을 사용하셨는데, 이 경우 기존 데이터프레임의 다른 수치형 컬럼이 손실될 수 있습니다. 데이터프레임에 한 번에 통합하여 적용하려면 아래와 같은 형태로 진행하는 것이 좋습니다.

수정된 코드 제안

train = pd.concat([train.drop(cols, axis=1), pd.get_dummies(train[cols])], axis=1)
test = pd.concat([test.drop(cols, axis=1), pd.get_dummies(test[cols])], axis=1)

코드 설명

  • train.drop(cols, axis=1): 기존의 범주형 컬럼을 삭제합니다.
  • pd.get_dummies(train[cols]): 인코딩된 새로운 컬럼 세트를 만듭니다.
  • pd.concat([...], axis=1): 삭제된 기존의 컬럼 대신 인코딩된 컬럼이 추가된 데이터를 생성합니다.

이 코드를 사용하면 데이터프레임 내의 다른 수치형 및 비인코딩 컬럼을 보존하면서 범주형 컬럼에 대해 원핫 인코딩을 수행할 수 있습니다.

아래 유사한 질문과 답변에서 좀 더 효과적인 방법 및 다양한 시각을 확인하실 수 있습니다:
- 원핫인코딩에 관해서 질문이 있습니다!
- pd.get_dummies(train[cols])와 (train, columns=cols) 차이가 궁금합니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

map 함수 사용 필수적인가요

0

13

1

수강 기한 연장 문의드립니다.

0

15

1

34강 평가지표

0

22

2

103강 작업2형 전처리(레이블인코딩 부분) 오류

0

14

2

작업형1_section14 문의

0

13

2

작업형1_연습문제 7번 관련입니다.

0

15

2

데이터 프레임 슬라이싱 혹은 데이터 선택하기가 어렵습니다.

0

13

2

크로스 밸리데이션 질문

0

19

2

로지스틱 회귀분석 질문

0

16

2

수치형 데이터만 선택하여 푸는 경우에 오답확률이 높아질까요?

0

24

2

2유형 object 컬럼 인코딩 관련 질문

0

34

2

하이퍼파라미터 변수

0

29

2

52강 이원분산분석

0

26

2

실제시험환경에서 작업형1,2,3의 문제풀이 순서

0

33

2

독립표본검정

0

26

2

tranform을 쓰라는 힌트는 어디서 얻을 수 있나요??

0

38

2

df.describe() 사용을 자제해야할까요?

0

38

2

shape 결과에 대한 문의

0

38

2

자료 문의

0

31

2

8 회귀 11번

0

27

2

심화 강의 관련 질문

0

39

2

빈도수 구하는 것 질문

0

26

2

커리큘럼을 따로 인쇄할 수 있는 방법이 있을까요?

0

40

1

작업형2 머신러닝 문제풀이 중 test 데이터 에러 문의

0

34

2