inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

작업형2 모의문제2

작업형2 모의문제 2 질문있습니다!

해결된 질문

468

화이팅

작성한 질문수 7

0

안녕하세요!

  1. 작업형 2 모의문제 2의 마지막에 csv파일을 제출할 때 에러가 발생하는데, 어떤 이유인지 찾아봐도 안보여 질문드립니다.

     

  2. 그리고 작업형 2유형의 train과 test데이터 파일만 주어진 경우, 어떤 문제는 n_train, c_train, n_test, c_test로 나누는 문제가 있고 그렇지 않은 문제들이 있어서 헷갈립니다ㅠ 그래서 문제를 읽고 데이터를 분리해야하는 상황이 궁금합니다!

import pandas as pd
train = pd.read_csv('train.csv')
test = pd.read_csv('test.csv')

# print(train.head())
# print(test.head())
# print(train.info()) 1. 불필요한 컬럼제거 2. 결측치 대치 3. 인코딩 4. 스케일링
# print(test.info())

train = train.drop(columns ='id')
test_id = test.pop('id')

# print(test_id)

cols = ['host_id','neighbourhood_group','neighbourhood','name', 'host_name', 'last_review']
# print(train.shape)
train = train.drop(cols, axis =1)
test = test.drop(cols, axis =1)
# print(train.shape)

# train = train.drop(columns ='host_id')
# test = test.drop(columns ='host_id')
# train = train.drop(columns ='neighbourhood_group')
# test = test.drop(columns ='neighbourhood_group')
# train = train.drop(columns ='neighbourhood')
# test = test.drop(columns ='neighbourhood')
# train = train.drop(columns ='name')
# test = test.drop(columns ='name')
# train = train.drop(columns ='host_name')
# test = test.drop(columns ='host_name')
# train = train.drop(columns ='last_review')
# test = test.drop(columns ='last_review')

# print(train.info())
# print(test.info())
# print(train.isnull().sum())
# print(test.isnull().sum())

train['reviews_per_month'] = train['reviews_per_month'].fillna(0)
test['reviews_per_month'] = test['reviews_per_month'].fillna(0)

# print(train.isnull().sum())
# print(test.isnull().sum())

#라벨 인코딩
from sklearn.preprocessing import LabelEncoder

cols =train.select_dtypes(include = 'object').columns

for col in cols:
  encoder = LabelEncoder()
  train[col] = encoder.fit_transform(train[col])
  test[col] = encoder.transform(test[col])

# print(train.info())
# print(test.info())

# print(train.describe())
# print(test.describe())

# 스케일링
from sklearn.preprocessing import minmax_scale

cols2 = train.select_dtypes(exclude = 'object').columns

for col in cols2:
  train[col] = minmax_scale(train[col])

cols2 = test.select_dtypes(exclude = 'object').columns

for col in cols2:
  test[col] = minmax_scale(test[col])

# print(train.describe())
# print(test.describe())

from sklearn.model_selection import train_test_split

X_train, X_val, y_train, y_val = train_test_split(train.drop('price', axis=1), train['price'], test_size=0.2, random_state=20)

# print(X_train.head())

from sklearn.ensemble import RandomForestRegressor
rf = RandomForestRegressor()

rf.fit(X_train, y_train)
pred = rf.predict(X_val)
# print(pred)

#id,price

sumit = pd.DataFrame({'id': test_id, 'price' : pred})
submit.to_csv('10004.csv', index=False)

 

 

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

답변 1

0

퇴근후딴짓

92번에 표시가 되어 있고 value에러가 발생했네요

내용을 읽어 보니 데이터의 길이가 맞지 않는 상황입니다.

92번을 살펴보니 test_id가 있고 pred가 있네요

둘 중 하나는 7824개고 나머지 하나는 9779로 예상되네요

왜 길이가 안맞을까요?

test_id는 그대로 복사한거니 큰 이슈가 없을 것 같고

pred를 의심해봐야겠네요

pred로 대입한 문장으로 따라 올라가보겠습니다.

코드를 살펴보니 예측한 결과 값은 맞는데 validation(검증)데이터 였네요!!

에러가 없으려면 test 데이터를 예측해야 합니다.

pred = rf.predict(X_val)

이렇게만 하면 validation을 나눈 의미가 없습니다.

검증데이터는 평가해보기 위해 분할한거에요~

 

2 전처리 방식의 차이 입니다

나누는 방식을 활용해도 되고, 컬럼을 선택하는 방식을 활용해도 됩니다. 다양한 방법이 있음을 보여드렸습니다.

 

수업노트가 어디에 있나요?

0

15

1

실기시험 제출관련

0

147

2

6.20 작업형 2 과적합

0

156

3

코딩팡 장업형2 베이스 라인 인코딩 종류 질문

0

48

2

로지스틱회귀, 회귀

0

47

2

회귀 문제를 풀때 질문입니다.

0

54

1

불균형 처리 후 성능이 더 낮아졌다면,

0

61

2

실기 체험 제2유형 에러 문의

0

61

1

LIGHTGBM 으로 하면 pred값이 소수점 6자리까지 나오는게 맞나요

0

49

2

3번문제 등분산 가정

0

47

2

작업형3 target 형 변환 질문

0

34

2

[작업형1] 연습문제 섹션1 ~ 10 의 section4

0

36

3

원핫인코딩과 레이블 인코딩에서 concat

0

58

2

제2유형 질문입니다.

0

46

2

C()

0

44

2

작업형 2에서 strafity 적용 유무

0

51

2

수강 기간 연장 가능 여부 문의드립니다.

0

60

1

ols

0

43

2

2유형 작성관련 질문(일반 심화)

0

39

2

2유형 작성관련 질문

0

41

2

2유형 object컬럼 개수 다르면

0

48

2

코딩팡질문이요ㅠㅠ

0

45

2

관찰값과 기대값의 개념이 헷갈립니다.

0

25

2

작업형2 ID 컬럼 삭제 질문

0

45

2