티스토리 뷰

190507 공부

내가 공부하려고 적는, 문자열이 있는 데이터프레임 처리하기

 

 

process (기존)

  1. 데이터 필드 타입 살펴보기

    data frame : numeric(38개 열) + categorical (3개 열)

    label : categorical (5개의 값)

    df.shape (4898431, 42)

     

  2. null 값 보기

    다행히 null값 없음

     

  3. train_test_split

     

  4. convert string to int

    x_train, x_test, y_train, y_test 모두 LabelEncoder와 OneHotEncoder를 사용하여 numeric으로 변환 후 바로 데이터셋에 집어넣음 --> 결과적으로 제대로 안들어감;;

 

  1. RandomForest 모델 적용하기

 

 

 

 

 

 

 

수정 1. LabelEncoder 객체 중복 방지

기존에 각 열 마다 레이블인코더를 바로 fit_transform했는데 이러면 처음에 protocol_type열에 대해 학습하고 변환한 객체를 그대로 다시 service열에 쓰게되기때문에 X.

이런식으로 각 열에 맞게 객체를 만들어주어야한다!!

 

 

 

 

 

수정 2. OneHotEncoder로 고친 후 기존 df에 넣기

기존방식으로하면 기껏 인코더 변환했는데 값이 [0,1,0] 이라면 첫 번째 값인 0만 데이터 프레임에 들어간다.. 그러니 concat으로 붙여넣어야한다.

 

 

 

 

 

 

수정3. 범주형이면 무조건 OneHotEncoding?

위의 protocol_type열은 unique()값이 3개였기에 원핫인코딩을 하는데 문제가 없었다. (데이터프레임 크기에 영향이 적음). 그러나 열의 unique()값이 70개라면? 그렇다면 70개의 열이 새로 생성되고 이는 모델의 성능에 영향을 미칠 수도 있다.

row는 약 367만개인데 서비스열의 카운트가 10미만으로 매우 작은 행들도 있다. 이런행까지 모두 열로 만들기는 부담스러우니 적당히 카운트가 적은 열들은 모아 '기타' 등으로 바꾸자. 약 0.01%, 3만6천개를 기준으로 이보다 카운트가 적으면 기타로 모두 넣는다.

 

 

 

 

수정4. 데이터 열의 type만 보는 함정에 빠지지마라

x_train열에는 obj 3개에 나머지열은 모두 int였다. 그래서 문자열만 숫자형으로 변환후 랜덤포레스트를 돌렸는데 열을 자세히 보면 is_host_login이라는 열이 있다. 그리고 이 열의 값을 살펴보면 오직 0과1 두개의 값으로만 구성되어있다. 즉, 이 열은 호스트가 로그인했는지 안했는지 나타내는 범주형 열이라는 사실 ^-^ .. 깔깔깔 범주형으로 처리해주어야겠죠?

공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2025/01   »
1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31
글 보관함