데이터 분리
작업형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,,,,인건가요??
출력값 질문
0
12
1
수업노트가 어디에 있나요?
0
21
1
실기시험 제출관련
0
154
2
6.20 작업형 2 과적합
0
158
3
코딩팡 장업형2 베이스 라인 인코딩 종류 질문
0
50
2
로지스틱회귀, 회귀
0
48
2
회귀 문제를 풀때 질문입니다.
0
56
1
불균형 처리 후 성능이 더 낮아졌다면,
0
62
2
실기 체험 제2유형 에러 문의
0
61
1
LIGHTGBM 으로 하면 pred값이 소수점 6자리까지 나오는게 맞나요
0
50
2
3번문제 등분산 가정
0
48
2
작업형3 target 형 변환 질문
0
35
2
[작업형1] 연습문제 섹션1 ~ 10 의 section4
0
36
3
원핫인코딩과 레이블 인코딩에서 concat
0
59
2
제2유형 질문입니다.
0
46
2
C()
0
44
2
작업형 2에서 strafity 적용 유무
0
52
2
수강 기간 연장 가능 여부 문의드립니다.
0
61
1
ols
0
43
2
2유형 작성관련 질문(일반 심화)
0
39
2
2유형 작성관련 질문
0
41
2
2유형 object컬럼 개수 다르면
0
48
2
코딩팡질문이요ㅠㅠ
0
45
2
관찰값과 기대값의 개념이 헷갈립니다.
0
25
2





