inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

오징어게임

해결된 질문

304

강샛별

작성한 질문수 14

0

선생님 이번 오징어 게임 미션을 하면서 작업형 2를 풀고 있습니다

import pandas as pd

train = pd.read_csv("../input/big-data-analytics-certification/t2-1-train.csv")

test = pd.read_csv("../input/big-data-analytics-certification/t2-1-test.csv")

train.head() #pop: 'TravelInsurance' drop:'id'

test.head() #pop:'id'

train.info() #'Employment Type','GraduateOrNot','FrequentFlyer','EverTravelledAbroad'

train.isnull().sum() #'AnnualIncome' 결측값

test.isnull().sum() #'AnnualIncome' 결측값

target = train.pop('TravelInsurance')

test_id = test.pop('id')

me = train['AnnualIncome'].mean()

train = train.fillna(me)

me = test['AnnualIncome'].mean()

test = test.fillna(me)

from sklearn.preprocessing import LabelEncoder

encoder = LabelEncoder()

train['Employment Type'] = encoder.fit_transform(train['Employment Type'])

train['GraduateOrNot'] = encoder.fit_transform(train['GraduateOrNot'])

train['FrequentFlyer'] = encoder.fit_transform(train['FrequentFlyer'])

train['EverTravelledAbroad'] = encoder.fit_transform(train['EverTravelledAbroad'])

test['Employment Type'] = encoder.fit_transform(test['Employment Type'])

test['GraduateOrNot'] = encoder.fit_transform(test['GraduateOrNot'])

test['FrequentFlyer'] = encoder.fit_transform(test['FrequentFlyer'])

test['EverTravelledAbroad'] = encoder.fit_transform(test['EverTravelledAbroad'])

from sklearn.model_selection import train_test_split

X_tr, X_val, y_tr, y_val = train_test_split(train, target, test_size=0.2, random_state=0)

from sklearn.ensemble import RandomForestClassifier

model = RandomForestClassifier(random_state=2022)

model.fit(X_tr, y_tr)

pred = model.predict_proba(X_val)

from sklearn.metrics import roc_auc_score

roc_auc_score(y_val, pred[:,1])

 

이렇게 코드를 작성했는데 예측하는 단계에서

pred = model.predict_proba(test) 이걸 썼더니

X has 8 features, but RandomForestClassifier is expecting 9 features as input.

이렇게 에러가 뜨는데 뭐가 잘못됐을까요?

 

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

답변 1

0

퇴근후딴짓

1

에러는 train 데이터와 test 데이터 간에 특성(컬럼)의 수가 일치하지 않음을 의미합니다.
test의 컬럼과 X_tr의 컬럼을 비교해주세요!

 

2

그리고 인코딩 방식이 잘못되었어요!
강의에서 알려준 코드대로 또는 캐글문 제라면 캐글에서 예시 답변으로 알려준대로 레이블 인코딩 또는 원핫인코딩을 진행해 주세요

시험이 얼마 남지 않은 관계로 문제가 없는 코드를 보고 학습하는 것이 더 효과적일 것 같아요!

출력값 질문

0

11

1

수업노트가 어디에 있나요?

0

21

1

실기시험 제출관련

0

153

2

6.20 작업형 2 과적합

0

158

3

코딩팡 장업형2 베이스 라인 인코딩 종류 질문

0

49

2

로지스틱회귀, 회귀

0

48

2

회귀 문제를 풀때 질문입니다.

0

55

1

불균형 처리 후 성능이 더 낮아졌다면,

0

61

2

실기 체험 제2유형 에러 문의

0

61

1

LIGHTGBM 으로 하면 pred값이 소수점 6자리까지 나오는게 맞나요

0

50

2

3번문제 등분산 가정

0

48

2

작업형3 target 형 변환 질문

0

35

2

[작업형1] 연습문제 섹션1 ~ 10 의 section4

0

36

3

원핫인코딩과 레이블 인코딩에서 concat

0

59

2

제2유형 질문입니다.

0

46

2

C()

0

44

2

작업형 2에서 strafity 적용 유무

0

52

2

수강 기간 연장 가능 여부 문의드립니다.

0

61

1

ols

0

43

2

2유형 작성관련 질문(일반 심화)

0

39

2

2유형 작성관련 질문

0

41

2

2유형 object컬럼 개수 다르면

0

48

2

코딩팡질문이요ㅠㅠ

0

45

2

관찰값과 기대값의 개념이 헷갈립니다.

0

25

2