inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

피처 엔지니어링

label encoding error

해결된 질문

154

김치현

작성한 질문수 31

0

n_train, n_test, c_train, c_test = get_nc_data() # 데이터 새로 불러오기
from sklearn.preprocessing import LabelEncoder
le = LabelEncoder()

for col in cols  :
  le = LabelEncoder()
  c_train[col] = le.fit_transform(c_train[col])
  c_test[col] = le.transform(c_test[col])

이렇게 했는데, 

---------------------------------------------------------------------------
KeyError                                  Traceback (most recent call last)
/usr/local/lib/python3.10/dist-packages/pandas/core/indexes/base.py in get_loc(self, key)
   3804         try:
-> 3805             return self._engine.get_loc(casted_key)
   3806         except KeyError as err:

index.pyx in pandas._libs.index.IndexEngine.get_loc()

index.pyx in pandas._libs.index.IndexEngine.get_loc()

pandas/_libs/hashtable_class_helper.pxi in pandas._libs.hashtable.PyObjectHashTable.get_item()

pandas/_libs/hashtable_class_helper.pxi in pandas._libs.hashtable.PyObjectHashTable.get_item()

KeyError: 'age'

The above exception was the direct cause of the following exception:

KeyError                                  Traceback (most recent call last)
2 frames
/usr/local/lib/python3.10/dist-packages/pandas/core/indexes/base.py in get_loc(self, key)
   3810             ):
   3811                 raise InvalidIndexError(key)
-> 3812             raise KeyError(key) from err
   3813         except TypeError:
   3814             # If we have a listlike key, _check_indexing_error will raise

KeyError: 'age'

age와 관련된 이상한 오류가 뜨네요...

python 머신러닝 빅데이터 pandas 빅데이터분석기사

답변 2

0

퇴근후딴짓

col를 출력해 보시겠어요?

col에는 age가 있는데

실제 c_train에는 age가 없는 것으로 보입니다.

 

cols를 정의한 코드를 확인해주세요!

0

인프런 AI 인턴

안녕하세요, 김치현님. 인프런 AI 인턴입니다.

LabelEncoder를 사용하는 과정에서 발생한 오류를 살펴보니, cols 리스트에 포함된 c_train 혹은 c_test 데이터프레임에 실제로 존재하지 않는 컬럼명 ‘age’ 때문에 문제가 발생한 것으로 보입니다. 일반적으로 KeyError는 데이터프레임에 존재하지 않는 열을 접근하려 할 때 발생합니다.

이 문제를 해결하기 위해 다음 사항을 점검해 보시길 권장합니다:

  1. 컬럼의 존재 여부 확인: c_trainc_test 데이터프레임에 ‘age’ 컬럼이 실제로 존재하는지 확인해보세요. 아래 코드를 사용해 컬럼 목록을 출력할 수 있습니다.

    print(c_train.columns)
    print(c_test.columns)
    
  2. 오타 확인: 컬럼명이 정확히 일치하는지, 오타가 없는지 확인해 주세요. ‘Age’, ‘AGE’, 또는 유사한 다른 이름일 가능성도 있습니다.

  3. 데이터프레임 초기화: get_nc_data() 함수를 통해 가져온 데이터 구조가 제대로 초기화되었는지 확인해 보세요. 데이터프레임이 제대로 초기화되지 않았다면, 컬럼이 누락되거나 손상됐을 수 있습니다.

이미 비슷한 문제가 있던 분의 질문을 참고할 수 있습니다. 이 경우 유사한 구조 문제로 고민한 예제가 도움이 될 수 있습니다:
- “Transform 관련 코드 이상”에서는 LabelEncoder와 관련된 여러 오류 해결 방법이 언급되었습니다.

이 문제 해결에 도움이 되었기를 바랍니다. 추가적인 질문이 있다면, 언제든지 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏

1유형 강의 다 나간 후 어떻게 할까요?

0

16

1

점수차가 많이 나는데 따로 하신게 있으신가요?

0

12

1

작업형1 모의문제 4번에 3)문제 질문

0

21

2

이상치 전처리 작업

0

25

2

평가결과값 문의

0

29

2

시계열 데이터 날짜와 시간 format

0

36

2

평가지표 F1 스코어 질문드립니다.

0

27

2

작업형 2 기출7회분에서

0

38

2

작업형2 모의문제1 (30강)

0

34

2

수강 기간 연장 문의 드립니다.

0

42

2

수강 계획과 관련해 문의 드립니다.

0

30

2

작업형1 - 연습문제 16~39 풀이는 몇강을 보면 되나요?

0

50

2

작업형 1 -연습문제 4-6

0

38

2

작업형 1 유형 부분

0

42

2

작업형 1 (삭제예정, 구 버전)

0

51

2

수강기간 연장 문의드립니다.

0

38

2

2유형 레이블 인코딩 VS 원핫 인코딩

0

37

3

수강기간 연장 문의드립니다.

0

45

2

인덱스 슬라이싱

0

37

2

질문 드립니다.

0

50

2

강의 내용 관련 질문드립니다~

0

46

2

수강 연장 문의

0

63

2

강의자료 일괄 다운로드

0

62

2

수강기간 연장 문의드립니다

0

48

2