데이터 전처리 IQR 이렇게 해도 되나요?
cols = list(X_train.columns[X_train.dtypes != object])
cols
for col in cols:
Q1 = X_train[col].quantile(.25)
Q3 = X_train[col].quantile(.75)
IQR = Q3-Q1
min_iqr = Q1 - 1.5*IQR
max_iqr = Q3 + 1.5*IQR
cnt_before = sum((X_train[col] < min_iqr) | (X_train[col] > max_iqr)) # (X_train[col] < min_iqr) | (X_train[col] > max_iqr), 주어진 조건 둘 중 하나라도 만족, 이상치를 나타내는 값을 선택하는 조건
print(f'{col}의 이상치 처리 전 이상치 개수: {cnt_before}개 입니다.') # f 접두사를 사용하여 문자열 안에서 중괄호 {} 안에 변수나 표현식을 넣을 수 있음
X_train = X_train[(X_train[col] >= min_iqr) & (X_train[col] <= max_iqr)] # (X_train[col] >= min_iqr) & (X_train[col] <= max_iqr), 주어진 조건 둘 다 만족, 이상치를 제외한 정상 범위의 데이터를 선택하는 조건
cnt_after = sum((X_train[col] < min_iqr) | (X_train[col] > max_iqr))
print(f'{col}의 이상치 처리 후 이상치 개수: {cnt_after}개 입니다.')
답변 1
0
작업형2에서 데이터 전처리를 IQR로 해도 되는지를 물어보는거죠?
(어떤 강의에서 질문이 나왔는지 확인이 안되서 정확히 파악을 못하겠습니다 🙌)
실제 데이터에서 IQR활용시 너무 많은 데이터가 삭제 되기도 합니다.
데이터에 따라 성능이 더 떨어질 수도 있고요~~
작업형2 데이터가 공개된 것이 아니므로 상황에 따라 달라지겠지만
경험상 위 전처리를 추천하진 않아요!
이상치 제거는 일단 생략하고 진행한 다음 제출을 1차, 2차 하고나서
여유가 있다면 한번쯤 시도하길 추천 해요
만약 작업형1을 묻는 것이라면 결과(정답)가 동일하면 방법은 코드는 다르게 해도 좋습니다.
작업형1은 정답이 있는 문제입니다
작업형1 강의 수강 완료 후..
0
9
0
작업형1 모의문제 4번에 3)문제 질문
0
15
2
이상치 전처리 작업
0
22
2
평가결과값 문의
0
27
2
시계열 데이터 날짜와 시간 format
0
31
2
평가지표 F1 스코어 질문드립니다.
0
24
2
작업형 2 기출7회분에서
0
37
2
작업형2 모의문제1 (30강)
0
34
2
수강 기간 연장 문의 드립니다.
0
41
2
수강 계획과 관련해 문의 드립니다.
0
28
2
작업형1 - 연습문제 16~39 풀이는 몇강을 보면 되나요?
0
50
2
작업형 1 -연습문제 4-6
0
38
2
작업형 1 유형 부분
0
42
2
작업형 1 (삭제예정, 구 버전)
0
51
2
수강기간 연장 문의드립니다.
0
38
2
2유형 레이블 인코딩 VS 원핫 인코딩
0
37
3
수강기간 연장 문의드립니다.
0
44
2
인덱스 슬라이싱
0
37
2
질문 드립니다.
0
50
2
강의 내용 관련 질문드립니다~
0
46
2
수강 연장 문의
0
63
2
강의자료 일괄 다운로드
0
61
2
수강기간 연장 문의드립니다
0
48
2
list 문제 질문드립니다~
0
38
2





