작업형2 모의문제 1 질문2
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으로만 나오는데 무엇이 잘못된건지 모르겠습니다ㅠㅠ
답변 2
1
비유를 한번해볼게요!!
어려운 시험을 모두 100점을 맞았다면 컨닝을 의심해 볼 필요가 있어요!
즉 X데이터에 label, target과 상관관계가 매우 높은 값이 들어갔거나 답이 함께 있는 경우죠!!
train_test_split(train<- 여기에 혹시 레이블 값이 함께 있는건 아닌지요?? 확인해주세요 !!
0
헉 저도 같은 현상인데요 ㅠㅠ 혹시 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
4
1
기출 문제와 실전챌린지 연습문제 무엇부터 푸는게 나은가요?
0
7
0
전처리 train() test([ ])
0
10
2
작업형 1 배경지식 질문
0
13
2
옳게 풀은건지 질문드립니다!
0
11
1
roc_auc_score
0
17
1
추가질문 합니다
0
12
1
시험환경 구름
0
13
1
2유형 질문드려요
0
10
1
RandomForest vs lgb
0
20
1
전처리 관련질문
0
16
2
작업형3 기출
0
14
1
유형2에서 데이터분할 생략 가능여부
0
25
2
9회 기출 유형3 질문
0
15
1
lgb 기초편
0
11
1
괄호 사용
0
17
1
작업형 2 데이터 전처리 질문
0
20
1
11회 기출 유형 작업형1 문제 3-1
0
16
0
예시문제 작업형2 (ver2023) 질문입니다
0
17
1
Data type에 따른 처리
0
18
2
데이터 전처리 관련
0
17
2
시험에서 문제 불러오기
0
18
2
2번문제 출력값 질문
0
24
2
pd.get_dummies()가 bool로 반환
0
19
2





