inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

작업형2 모의문제1

작업형2 모의문제 1 질문2

해결된 질문

478

김태범

작성한 질문수 15

1

import pandas as pd

train = pd.read_csv("train.csv")
test = pd.read_csv("test.csv")
from sklearn.metrics import accuracy_score, precision_score, recall_score, f1_score, roc_auc_score
train

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

from sklearn.preprocessing import MinMaxScaler
cols = ['Customer_Age','Dependent_count', 'Months_on_book', 'Total_Relationship_Count',	'Months_Inactive_12_mon',	'Contacts_Count_12_mon',	'Credit_Limit',	'Total_Revolving_Bal',	'Avg_Open_To_Buy',	'Total_Amt_Chng_Q4_Q1',	'Total_Trans_Amt',	'Total_Trans_Ct',	'Total_Ct_Chng_Q4_Q1',	'Avg_Utilization_Ratio']

scaler = MinMaxScaler()
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('CLIENTNUM', axis =1)
test = test.pop('CLIENTNUM')

from sklearn.model_selection import train_test_split
X_tr, X_val, y_tr, y_val = train_test_split(
                                              train,
                                              train['Attrition_Flag'],
                                              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(X_val)
print(pred)
# 정확도
print(accuracy_score(y_val, pred))

# 정밀도
print(precision_score(y_val, pred))

# 재현율 (민감도)
print(recall_score(y_val, pred))

# F1
print(f1_score(y_val , pred))

위와 같이 코드를 진행시

[0 1 0 ... 1 0 1]

1.0

1.0

1.0

1.0

 

이 나옵니다. pred 자체가 1차원으로만 나오고 정확도 정밀도 재현율 F1도 1.0으로만 나오는데 무엇이 잘못된건지 모르겠습니다ㅠㅠ

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

답변 2

1

퇴근후딴짓

비유를 한번해볼게요!!

어려운 시험을 모두 100점을 맞았다면 컨닝을 의심해 볼 필요가 있어요!

즉 X데이터에 label, target과 상관관계가 매우 높은 값이 들어갔거나 답이 함께 있는 경우죠!!

train_test_split(train<- 여기에 혹시 레이블 값이 함께 있는건 아닌지요?? 확인해주세요 !!

0

ji_nhee

헉 저도 같은 현상인데요 ㅠㅠ 혹시 train_test_split( train 여기서 train이라고 쓰면 안되나요? 강의하실때는 저 train부분에 train.drop('Attrition_Flag'axis=1) 을 넣으셨는데, 혼자 연습할떄 어차피 위의 과정에서 train = train.drop('Attrition_Flag'axis=1 이니, 그냥 train을 썼거든요.. 1.0으로만 나오는게 이게 영향이 있나요?

1

퇴근후딴짓

다른 문제인 것같아요! 태범님은 train['Attrition_Flag'].drop이 없어 발생했고
ji_nhee님은 드랍 했다면 코드를 봐야 확인가능할 것 같아요!!
코드를 "코드블럭" 아이콘을 누른후 넣어서 보여주시겠어요?

평가결과값 문의

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