inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

[퇴근후딴짓] 빅데이터 분석기사 실기 (작업형1,2,3)

작업형2 모의문제1

원핫인코딩 질문

해결된 질문

127

gniddup5

작성한 질문수 3

0

강의에 알려주신대로 따라서 하고 있는데 원핫인코딩 결과에 income category랑 card category만 뜨고 나머지 object컬럼(gender 등)은 뜨질 않습니다.. 뭐가 문제인지 알려주실 수 있을까요?

#baseline(object컬럼 제거)
cols = train.select_dtypes(include='object').columns
# print(train.shape, test.shape)
# train = train.drop(cols, axis=1)
# test = test.drop(cols,axis=1)
# print(train.shape, test.shape)

# 라벨인코딩
# from sklearn.preprocessing import LabelEncoder
# for col in cols:
#   le = LabelEncoder()
#   train[col] = le.fit_transform(train[col])
#   test[col] = le.transform(test[col])

# train.head()

# onehot 인코딩
pd.get_dummies(train, columns=cols)

마지막에 8101 rows × 39 columns 라고 뜨는데 그냥 표시만 안 된건가요?

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

답변 2

0

퇴근후딴짓

대입(=) 연산자를 통해 저장이 필요합니다.

train = pd.get_dummies(train, columns=cols)

또는

train = pd.get_dummies(train) 만 작성하더라도 범주형만 자동으로 처리합니다.

0

인프런 AI 인턴

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

gniddup5님의 질문을 보면, pd.get_dummies() 함수를 사용하여 데이터프레임의 특정 object형 컬럼들을 원핫 인코딩하려는 시도를 하셨네요. 여기서 겪고 계신 문제에 대한 가능성 있는 몇 가지 설명을 드리겠습니다.

1. pd.get_dummies() 결과가 새로운 데이터프레임을 반환

pd.get_dummies(train, columns=cols)는 원핫 인코딩된 새로운 데이터프레임을 반환합니다. 이 코드를 실행하고 나면 원래의 train 데이터프레임은 변하지 않습니다. 따라서 원핫 인코딩된 결과가 변수에 할당되지 않으면 화면에 표시되지 않을 수 있습니다.

train_encoded = pd.get_dummies(train, columns=cols)

위와 같이 새로운 변수에 할당함으로써 원핫 인코딩된 결과를 확인 및 사용할 수 있습니다.

2. 특정 컬럼이 인코딩되지 않는 이유

만약 특정 컬럼들, 예를 들어 gender가 원핫 인코딩 결과에 포함되지 않는다면, 해당 컬럼에 대한 경로에서의 문제일 수 있습니다. 원인은 레코드의 변동이나 데이터 셋의 경로에서의 문제일 가능성이 있습니다. 또는 그 부분에서 cols 변수에 어떠한 오류가 있을 수 있습니다.

  • cols 객체의 프린트를 통해 실제 어떤 컬럼들이 인코딩 대상으로 설정되어 있는지를 확인해보세요:
    
    print(cols)
    

3. 결과 컬럼 갯수 확인

8101 rows × 39 columns 중에서 인코딩된 컬럼이 표시되지 않는다면, 판다스의 출력 제한 때문일 수 있습니다. pd.set_option('display.max_columns', None)을 사용하여 모든 컬럼을 출력하도록 설정할 수 있습니다.

다른 질문에 대한 유사한 해결방법들

비슷한 고민을 겪고 있는 질문자들이 pd.get_dummies() 활용에 대해 답변을 남기셨습니다. 원핫 인코딩 과정에서 특정 컬럼이 예상대로 변환되지 않는 문제를 해결하기 위해 이 답변들을 참고해 보시는 것을 추천드립니다.

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

작업형2 카테고리

0

7

1

110강 회귀_8번 문의

0

8

2

XGBRegressor 학습 시 warning 출력

0

13

2

데이터 프레임을 변경해도 되나요?

0

10

2

10회 기출 작업형3 문제 2-1 질문

0

15

2

작업형 2 질문

0

15

2

작업형 2 템플릿 확인 요청

0

13

2

작업형2 인코딩 질문

0

22

2

작업형 3 벼락치기 공부방법 질문

0

30

2

기출 11회 작업형 2_전체 데이터 학습 여부

0

31

2

예측값 결과 소수점 차이

0

28

2

기출 문제와 실전챌린지 연습문제 무엇부터 푸는게 나은가요?

0

35

1

전처리 train() test([ ])

0

23

2

작업형 1 배경지식 질문

0

32

2

옳게 풀은건지 질문드립니다!

0

22

1

roc_auc_score

0

30

2

추가질문 합니다

0

22

2

시험환경 구름

0

20

2

2유형 질문드려요

0

21

2

RandomForest vs lgb

0

28

2

전처리 관련질문

0

29

3

작업형3 기출

0

20

2

유형2에서 데이터분할 생략 가능여부

0

33

2

9회 기출 유형3 질문

0

21

2