inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

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

기출2 작업형1

해결된 질문

83

홍영준

작성한 질문수 12

0

# your code
import pandas as pd
df = pd.read_csv("https://raw.githubusercontent.com/lovedlim/inf/refs/heads/main/p1/members.csv")

df.head(3)
df = df.sort_values('views',ascending=False).head(10)
df
r1 = 9690.0
df.iloc[:10,-1] = r1

cond = df['age'] >=80
print(df[cond]['views'].mean())

안녕하세요 10번째 최소값을 r1= 9690.0 으로 지정 후

df.iloc[:10.-1] = r1로 지정후 결과를 냈더니

9690.0으로 나오는데 왜그런걸까요?

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

답변 2

0

퇴근후딴짓

df = df.sort_values('views',ascending=False).head(10)

head(10) 코드로 df에 10개의 데이터 밖에 남자않았어요

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. 홍영준님.

주어진 코드에서 발생한 문제는 df.iloc[:10, -1]으로 잘못 설정된 데이터 조작 방식 때문입니다. 이 경우, -1은 마지막 컬럼(views)을 나타내며, iloc 메서드로 사용하는 것은 데이터프레임의 행과 열을 위치 기반으로 지정할 때 발생할 수 있는 오류를 유발할 수 있습니다.

문제 해결 과정

  1. views 컬럼을 수동으로 설정하기 위해서는 df['views']로 명시적으로 지정하는 것이 좋습니다. 예를 들어, df.loc[df.index[:10], 'views'] = r1로 설정할 수 있습니다. 이렇게 하면 iloc 방식 대신 loc를 사용하여 명시적으로 지정할 수 있습니다.

  2. 현재는 데이터프레임이 전체 데이터로 정렬된 상황이 아닙니다. 처음부터 10개만 슬라이싱하여 iloc를 사용하고자 한다면, 가급적 loc로 대체하는 것이 좋습니다.

수정된 코드는 아래와 같습니다.

import pandas as pd
df = pd.read_csv("https://raw.githubusercontent.com/lovedlim/inf/refs/heads/main/p1/members.csv")

# 상위 10개를 10번째 값으로 설정
r1 = 9690.0
df = df.sort_values('views', ascending=False)
df.loc[df.index[:10], 'views'] = r1  # 명시적으로 'views' 컬럼 지정

# 조건에 맞는 데이터 필터링 및 평균
cond = df['age'] >= 80
print(df[cond]['views'].mean())

참고 사항

  • iloc 사용 시 위치 기반으로 데이터프레임에 접근하기 때문에 복잡한 작업에는 loc를 사용할 것을 권장합니다. loc는 레이블을 기반으로 동작하므로 명확하고 안전하게 데이터를 수정할 수 있습니다.

참고 링크

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

110강 회귀_8번 문의

0

6

2

XGBRegressor 학습 시 warning 출력

0

9

2

데이터 프레임을 변경해도 되나요?

0

7

2

10회 기출 작업형3 문제 2-1 질문

0

12

2

작업형 2 질문

0

12

2

작업형 2 템플릿 확인 요청

0

12

2

작업형2 인코딩 질문

0

22

2

작업형 3 벼락치기 공부방법 질문

0

30

2

기출 11회 작업형 2_전체 데이터 학습 여부

0

30

2

예측값 결과 소수점 차이

0

26

2

기출 문제와 실전챌린지 연습문제 무엇부터 푸는게 나은가요?

0

34

1

전처리 train() test([ ])

0

23

2

작업형 1 배경지식 질문

0

31

2

옳게 풀은건지 질문드립니다!

0

21

1

roc_auc_score

0

29

2

추가질문 합니다

0

21

2

시험환경 구름

0

19

2

2유형 질문드려요

0

20

2

RandomForest vs lgb

0

27

2

전처리 관련질문

0

29

3

작업형3 기출

0

19

2

유형2에서 데이터분할 생략 가능여부

0

32

2

9회 기출 유형3 질문

0

21

2

lgb 기초편

0

22

2