강의

멘토링

로드맵

Inflearn brand logo image

인프런 커뮤니티 질문&답변

작성자 없음

작성자 정보가 삭제된 글입니다.

[퇴근후딴짓] 빅데이터 분석기사 실기 (작업형1,2,3)

6회 기출유형 (작업형2)

6회 기출 작업형2 오류 파악

해결된 질문

작성

·

30

·

수정됨

0

import pandas as pd
train = pd.read_csv("https://raw.githubusercontent.com/lovedlim/inf/refs/heads/main/p4/6_2/energy_train.csv")
test = pd.read_csv("https://raw.githubusercontent.com/lovedlim/inf/refs/heads/main/p4/6_2/energy_test.csv")


X_train = train.drop(['Heat_Load'], axis = 1)
y_train = train['Heat_Load']
X_test = test

from sklearn.preprocessing import LabelEncoder
encoder = LabelEncoder()
X_train['Roof'] = encoder.fit_transform(X_train['Roof'])
X_test['Roof'] = encoder.transform(X_test['Roof'])
X_train['Height'] = encoder.fit_transform(X_train['Height'])
X_test['Height'] = encoder.transform(X_test['Height'])
X_train['Orient'] = encoder.fit_transform(X_train['Orient'])
X_test['Orient'] = encoder.transform(X_test['Orient'])

num_columns = X_train.select_dtypes(exclude = 'object').columns
from sklearn.preprocessing import MinMaxScaler
scaler = MinMaxScaler()
X_train[num_columns] = scaler.fit_transform(X_train[num_columns])
X_test[num_columns] = scaler.transform(X_test[num_columns])

from sklearn.model_selection import train_test_split
X_train, X_val, y_train, y_val = train_test_split(X_train, y_train, test_size =0.2, random_state=2025)
print(X_train.shape, X_val.shape, y_train.shape, y_val.shape)

from sklearn.ensemble import RandomForestRegressor
model = RandomForestRegressor()
model.fit(X_train, y_train)
y_val_pred = model.predict(X_val)

 ValueError: could not convert string to float: 'High'

위와 같이 작성하였는데 해당오류가 뜹니다. 라벨인코딩은 진행하였는데 왜 오류가 발생할까요??.. 원핫인코딩을 진행해야하나요?

 

답변 2

0

퇴근후딴짓님의 프로필 이미지
퇴근후딴짓
지식공유자

삭제된 질문으로 확인

0

안녕하세요, 인프런 AI 인턴입니다.

chltjgmlexit님, 질문 주신 코드에서 발생한 오류는 LabelEncoder를 사용할 때 객체 데이터가 완전히 수치로 변환되지 않아서 발생한 문제입니다. LabelEncoder는 주로 범주형 데이터를 순차적인 정수로 변환할 때 사용되지만, 여러 열에 대해 동시에 라벨 인코딩이 올바르게 완료되지 않았거나, 인코딩 대상이 아닌 열에 대해 인코딩을 시도한 것일 수 있습니다.

이 문제를 해결하기 위해서는 다음 두 가지 방법을 고려해볼 수 있습니다:

  1. OneHotEncoding 사용: LabelEncoder 대신 OneHotEncoder를 사용하면 모든 범주형 특성이 각각의 열로 변환되어 데이터 간의 관계를 더 잘 유지할 수 있습니다.
   from sklearn.preprocessing import OneHotEncoder

   encoder = OneHotEncoder(drop='first', sparse=False)
   X_train_encoded = encoder.fit_transform(X_train[['Roof', 'Height', 'Orient']])
   X_test_encoded = encoder.transform(X_test[['Roof', 'Height', 'Orient']])

   X_train = X_train.drop(['Roof', 'Height', 'Orient'], axis=1)
   X_test = X_test.drop(['Roof', 'Height', 'Orient'], axis=1)

   X_train = pd.concat([X_train, pd.DataFrame(X_train_encoded)], axis=1)
   X_test = pd.concat([X_test, pd.DataFrame(X_test_encoded)], axis=1)
  1. pd.get_dummies() 함수 사용: Python의 pandas 라이브러리에서 제공하는 get_dummies 함수를 활용하여 범주형 변수를 더미 변수로 변환하는 방법도 있습니다.
   X_train = pd.get_dummies(X_train, columns=['Roof', 'Height', 'Orient'], drop_first=True)
   X_test = pd.get_dummies(X_test, columns=['Roof', 'Height', 'Orient'], drop_first=True)

이러한 방식으로 코드를 수정하면 범주형 데이터가 알맞게 변환되어 오류를 줄일 수 있습니다.

관련된 다른 유사한 해결 사례로 아래 링크의 답변들을 참고할 수 있습니다:

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

작성자 없음

작성자 정보가 삭제된 글입니다.

질문하기