작업형2에서 train, test 합쳐서 인코딩 후 분리하는 부분 질문입니다.
98
작성한 질문수 3
안녕하세요 강사님!
[3-4 Feature engineering.ipynb] 파일 복습 중에
# train, test 합쳐서 인코딩 후 분리하기
cols = list(X_train.columns[X_train.dtypes == object])
print(X_train.shape, X_test.shape)
all_df = pd.concat([X_train, X_test])
all_df = pd.get_dummies(all_df[cols])
line = int(X_train.shape[0])
X_train = all_df.iloc[:line,:].copy()
X_train
X_test = all_df.iloc[line:,:].copy()
X_test
print(X_train.shape, X_test.shape)이부분에서 '원핫인코딩' 대신 '레이블인코딩'을 하면 어떻게 해야될지 의문점이 생겼습니다.
레이블 인코딩시에는 train데이터에는 fit_transform() 을 하고 test 데이터에는 transform() 을 하는 것으로 알고 있는데 X_train 데이터와 X_test 데이터를 합쳤을 때는 fit_transform(), transform() 둘 중 어떤 것을 사용하고나서 분리해야되는지 궁금해서 질문 드립니다!
아래는 fit_transform()을 이용해서 구현해본 코드입니다.
X_train.shape, X_test.shape
df = pd.concat([X_train, X_test])
df.select_dtypes(include='O').columns
c_cols = ['workclass', 'education', 'marital.status', 'occupation',
'relationship', 'race', 'sex', 'native.country']
df.select_dtypes(exclude='O').columns
n_cols = ['age', 'fnlwgt', 'education.num', 'capital.gain', 'capital.loss',
'hours.per.week']
from sklearn.preprocessing import LabelEncoder
for col in c_cols:
le = LabelEncoder()
df[col] = le.fit_transform(df[col])
line = len(X_train)
X_train = df.iloc[:line,:].copy()
X_test = df.iloc[line:,:].copy()
print(X_train.shape, X_test.shape)
답변 1
작업형 1 유형 부분
0
9
1
작업형 1 (삭제예정, 구 버전)
0
28
2
수강기간 연장 문의드립니다.
0
20
1
2유형 레이블 인코딩 VS 원핫 인코딩
0
21
3
수강기간 연장 문의드립니다.
0
26
1
인덱스 슬라이싱
0
27
2
질문 드립니다.
0
45
2
강의 내용 관련 질문드립니다~
0
43
2
수강 연장 문의
0
54
2
강의자료 일괄 다운로드
0
49
2
수강기간 연장 문의드립니다
0
40
2
list 문제 질문드립니다~
0
34
2
빅분기 실기 12회 재도전
0
52
2
강의 기간 연장 가능여부 검토 요청건
0
39
2
수강기간 연장 문의 드립니다
0
43
2
수강기간 연장 문의드립니다
0
50
2
질문이요
0
55
2
수강기간 연장 문의드립니다.
0
58
2
문제 3-2 질문드립니다
0
47
2
수강기간 연장 문의 드립니다.
0
61
2
변수, 칼럼 , df 구분
0
51
2
수강기간 연장 문의드립니다.
0
50
2
수강기간 연장 문의
0
49
2
수강기간 연장 문의드립니다.
0
42
2





