데이터 분리
작업형2 에서 심장마비 확률 문제였는데요
여기서 데이터 전처리를 할때
X_train.drop('id' , axis =1)
X_test.pop('id)' 를 하고
데이터 분리할때 from sklearn.model_selection import train_test_split X_tr, X_val, y_tr, y_val = train_test_split(train.drop('output', axis=1), train['output'], test_size=0.15, random_state=2022)
이렇게 하신다고 했는데 위에서는 id를 드롭하고 분리할대는 'output'을 drop 하는건가요? 그리고 test는 왜 분리 하지 않는지 궁금합니다
답변 1
0
위에서는 id를 드롭하고 분리할 때는 'output'을 drop하는 건가요?
네, 맞습니다. id는 대부분의 경우 모델링에 필요하지 않은 정보이므로 삭제됩니다. output은 타겟 변수로써, X(피처)와 y(타겟)를 분리할 때 사용됩니다.
분리할 때가 아닌 미리 target을 변수에 담고, drop해도 됩니다.
target = train['output'] X_train = train.drop('output', axis=1) train_test_split(X_train, target)또는
target = train.pop('output')
train_test_split(X_train, target)
테스트 데이터는 왜 분리하지 않나요?
test데이터에는 target이 없습니다.
추가적으로
id값이 숫자라면 train, test 모두 제거하지 않아도 됩니다. 모델이 자동으로 중요도를 낮게 책정합니다.
문자라면 인코딩이 필요해 번거로워 삭제하는 것이 좋습니다.
단 여기서 말하는 id는 데이터 수가 100개일 때 100개 모두 다른 데이터를 가정하겠습니다.
test의 id는 문제에 따라 최종 제출 때 사용할 때가 있었습니다. (csv파일 생성 시) 따라서 pop을 활용해 다른 변수에 저장을 해뒀습니다. pop는 드랍 + 변수에 대입하는 2가지 기능이 있습니다.
0
target = train['output']
X_train = train.drop('output', axis=1) train_test_split(X_train, target)
만약에 이렇게 하면 ,,,X_train.drop('id' , axis =1)이거 대신에 위에 처럼 하는건가요?
id대신에 output를 drop,,,,인건가요??
작업형2 모의문제1 (30강)
0
20
2
수강 기간 연장 문의 드립니다.
0
24
2
수강 계획과 관련해 문의 드립니다.
0
22
2
작업형1 - 연습문제 16~39 풀이는 몇강을 보면 되나요?
0
47
2
작업형 1 -연습문제 4-6
0
34
2
작업형 1 유형 부분
0
40
2
작업형 1 (삭제예정, 구 버전)
0
50
2
수강기간 연장 문의드립니다.
0
36
2
2유형 레이블 인코딩 VS 원핫 인코딩
0
36
3
수강기간 연장 문의드립니다.
0
42
2
인덱스 슬라이싱
0
35
2
질문 드립니다.
0
50
2
강의 내용 관련 질문드립니다~
0
46
2
수강 연장 문의
0
63
2
강의자료 일괄 다운로드
0
58
2
수강기간 연장 문의드립니다
0
48
2
list 문제 질문드립니다~
0
38
2
빅분기 실기 12회 재도전
0
62
2
강의 기간 연장 가능여부 검토 요청건
0
50
2
수강기간 연장 문의 드립니다
0
46
2
수강기간 연장 문의드립니다
0
52
2
질문이요
0
57
2
수강기간 연장 문의드립니다.
0
60
2
문제 3-2 질문드립니다
0
47
2





