inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

2회 기출유형(작업형2)

작업형2 빅데이터 분석기사 2회 실기 질문

해결된 질문

535

김태범

작성한 질문수 15

0

df = pd.concat([X_train,y_train['Reached.on.Time_Y.N']], axis=1)

n_train = df.select_dtypes(exclude = object).copy()
c_train = df.select_dtypes(include = object).copy()
n_test = df.select_dtypes(exclude = object).copy()
c_test = df.select_dtypes(include = object).copy()

from sklearn.preprocessing import MinMaxScaler
scaler = MinMaxScaler()
cols = ['Customer_care_calls','Customer_rating', 'Cost_of_the_Product', 'Prior_purchases', 'Discount_offered', 'Weight_in_gms']
n_train[cols] = scaler.fit_transform(n_train[cols])
n_test[cols] = scaler.transform(n_test[cols])

c_train = pd.get_dummies(c_train)
c_test = pd.get_dummies(c_test)

train = pd.concat([n_train, c_train], axis =1)
test = pd.concat([n_test, c_test], axis =1)

train = train.drop('ID', axis =1)
test_id = test.pop('ID') 

from sklearn.model_selection import train_test_split
X_tr, X_val, y_tr, y_val = train_test_split(
                                              train.drop('Reached.on.Time_Y.N', axis =1),
                                              train['Reached.on.Time_Y.N'],
                                              test_size = 0.2,
                                              random_state = 2023)

from sklearn.ensemble import RandomForestClassifier
from sklearn.metrics import roc_auc_score

model = RandomForestClassifier(random_state = 2023)
model.fit(X_tr, y_tr)
pred = model.predict_proba(X_val)[:,1]
print(roc_auc_score(y_val, pred))

pred = model.predict_proba(test)[:,1]
submit = pd.DataFrame({
                        'ID': test_id,
                        'Reached.on.Time_Y.N': pred
})
submit.to_csv("0000.csv", index = False)

작업형2를 n_train, n_test, c_train, c_test로 나누어서 풀어보는 연습을 하고있는데요

위와 같이 코딩을 했는데 roc_auc_score는 잘 출력이 되지만 아래와 같은 워닝이 뜹니다. 이유를 알 수 있을까요?

 

0.7289745856473446
---------------------------------------------------------------------------
ValueError                                Traceback (most recent call last)
<ipython-input-81-0b0c32327ea7> in <cell line: 38>()
     36 print(roc_auc_score(y_val, pred))
     37 
---> 38 pred = model.predict_proba(test)[:,1]
     39 submit = pd.DataFrame({
     40                         'ID': test_id,


3 frames


/usr/local/lib/python3.10/dist-packages/sklearn/base.py in _check_feature_names(self, X, reset)
    479                 )
    480 
--> 481             raise ValueError(message)
    482 
    483     def _validate_data(

ValueError: The feature names should match those that were passed during fit.
Feature names unseen at fit time:
- Reached.on.Time_Y.N


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

답변 1

0

퇴근후딴짓

이건 워닝이 아니고 에러입니다.

에러는 반드시 코드를 수정해야 합니다.

train과 test 컬럼명을 확인해주겠어요? 뭔가 다른 컬럼명이 있는 것 같아요!

df.columns

평가결과값 문의

0

2

1

시계열 데이터 날짜와 시간 format

0

15

1

평가지표 F1 스코어 질문드립니다.

0

16

2

작업형 2 기출7회분에서

0

32

2

작업형2 모의문제1 (30강)

0

28

2

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

0

35

2

수강 계획과 관련해 문의 드립니다.

0

26

2

작업형1 - 연습문제 16~39 풀이는 몇강을 보면 되나요?

0

49

2

작업형 1 -연습문제 4-6

0

35

2

작업형 1 유형 부분

0

42

2

작업형 1 (삭제예정, 구 버전)

0

51

2

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

0

37

2

2유형 레이블 인코딩 VS 원핫 인코딩

0

37

3

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

0

44

2

인덱스 슬라이싱

0

36

2

질문 드립니다.

0

50

2

강의 내용 관련 질문드립니다~

0

46

2

수강 연장 문의

0

63

2

강의자료 일괄 다운로드

0

58

2

수강기간 연장 문의드립니다

0

48

2

list 문제 질문드립니다~

0

38

2

빅분기 실기 12회 재도전

0

63

2

강의 기간 연장 가능여부 검토 요청건

0

51

2

수강기간 연장 문의 드립니다

0

46

2