원핫인코딩 코드 질문
3
投稿した質問数 4
작업형2 모의문제2 11분12초의 레이블인코딩이 아닌 원핫인코딩으로 변경하는 코드에 대해서 질문드립니다.
만약 원핫인코딩으로 진행하려면 아래와 같이 코드를 작성하면 될까요?
# 원핫인코딩
train = train.drop('price', axis = 1)
train = pd.get_dummies(train)
test = pd.get_dummies(test)그리고 원핫인코딩으로 변경하면 검증데이터 분리 과정에서 코드를 어떻게 수정해야하나요?(.pop()을 사용해서 'price' 컬럼을 따로 변수에 저장한 후에 target 부분에 넣어야할까요?)
X_tr, X_val, y_tr, y_val = train_test_split(train,
target,
test_size = 0.2,
random_state = 0
)
回答 1
0
안녕하세요, 인프런 AI 인턴입니다. HOJUN CHOI님.
원핫 인코딩을 수행할 때에는 pd.get_dummies() 함수를 사용하여 범주형 데이터를 이진화된 형태로 변환할 수 있습니다. 질문하신 코드에서 몇 가지 수정이 필요할 수 있습니다.
원핫 인코딩 코드 설명
pd.get_dummies()함수의 사용 방식: 이 함수는 주어진 데이터프레임의 범주형 컬럼을 원핫 인코딩하여 반환합니다. 주의할 점은train[cols]와 같이 인코딩하면 결과가 여러 컬럼으로 확장되므로, 이를 새로운 데이터프레임으로 저장해야 기존 데이터프레임의 다른 컬럼들과 합쳐질 수 있습니다.인코딩 컬럼 지정:
- 원래 코드에서는
train[cols] = pd.get_dummies(train[cols])을 사용하셨는데, 이 경우 기존 데이터프레임의 다른 수치형 컬럼이 손실될 수 있습니다. 데이터프레임에 한 번에 통합하여 적용하려면 아래와 같은 형태로 진행하는 것이 좋습니다.
- 원래 코드에서는
수정된 코드 제안
train = pd.concat([train.drop(cols, axis=1), pd.get_dummies(train[cols])], axis=1)
test = pd.concat([test.drop(cols, axis=1), pd.get_dummies(test[cols])], axis=1)
코드 설명
train.drop(cols, axis=1): 기존의 범주형 컬럼을 삭제합니다.
pd.get_dummies(train[cols]): 인코딩된 새로운 컬럼 세트를 만듭니다.
pd.concat([...], axis=1): 삭제된 기존의 컬럼 대신 인코딩된 컬럼이 추가된 데이터를 생성합니다.
이 코드를 사용하면 데이터프레임 내의 다른 수치형 및 비인코딩 컬럼을 보존하면서 범주형 컬럼에 대해 원핫 인코딩을 수행할 수 있습니다.
아래 유사한 질문과 답변에서 좀 더 효과적인 방법 및 다양한 시각을 확인하실 수 있습니다:
- 원핫인코딩에 관해서 질문이 있습니다!
- pd.get_dummies(train[cols])와 (train, columns=cols) 차이가 궁금합니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
map 함수 사용 필수적인가요
0
13
1
수강 기한 연장 문의드립니다.
0
15
1
34강 평가지표
0
22
2
103강 작업2형 전처리(레이블인코딩 부분) 오류
0
14
2
작업형1_section14 문의
0
13
2
작업형1_연습문제 7번 관련입니다.
0
15
2
데이터 프레임 슬라이싱 혹은 데이터 선택하기가 어렵습니다.
0
13
2
크로스 밸리데이션 질문
0
19
2
로지스틱 회귀분석 질문
0
16
2
수치형 데이터만 선택하여 푸는 경우에 오답확률이 높아질까요?
0
24
2
2유형 object 컬럼 인코딩 관련 질문
0
34
2
하이퍼파라미터 변수
0
29
2
52강 이원분산분석
0
26
2
실제시험환경에서 작업형1,2,3의 문제풀이 순서
0
33
2
독립표본검정
0
26
2
tranform을 쓰라는 힌트는 어디서 얻을 수 있나요??
0
38
2
df.describe() 사용을 자제해야할까요?
0
38
2
shape 결과에 대한 문의
0
38
2
자료 문의
0
31
2
8 회귀 11번
0
27
2
심화 강의 관련 질문
0
39
2
빈도수 구하는 것 질문
0
26
2
커리큘럼을 따로 인쇄할 수 있는 방법이 있을까요?
0
40
1
작업형2 머신러닝 문제풀이 중 test 데이터 에러 문의
0
34
2

