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

아함님의 프로필 이미지
아함

작성한 질문수

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

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

안녕하세요! sum 함수를 쓸 곳에 len을 썼다가 의문이 생겨서 질문드립니다!

해결된 질문

작성

·

370

0

안녕하세요, 좋은 강의 잘 듣고 있습니다!

다름이 아니라 3회 기출 작업형 1번(문제2) 강의

- 2000년 데이터 중 2000년 평균보다 큰 값의 데이터 수 구하기에서

 

선생님이께서

cond = df.loc[2000].mean()
print(sum(df.loc[2000,:]>cond))

으로 'sum'을 쓰신 부분(결과값 100)을

저는

print(len(df.loc[2000,:]>cond))

로 쓰니, 저는 전체 행의 개수가 계속 출력(결과값 200)이 나오더라구요.

 

이유가 뭔지 생각해봐도 제 얄팍한 지식으로는 도무지 생각이 안나서 선생님의 답변을 듣고싶어 질문드립니다!

답변 1

2

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

안녕하세요:)

  1. sum()함수 -> 합계

    1. 모든 값을 더하는 함수입니다.

    2. df.loc[2000,:]>cond 만 출력을 해보면 행별로 조건에 맞으면 True, 아니면 False입니다.

    3. True는 1, False는 0이에요

    4. 따라서 합계를 계산하면 조건에 만족하는 데이터 수를 구할 수가 있어요

  2. len()함수 -> 데이터프레임에서는 행의 수를 구합니다.

    1. 만약 이 문제에서 len()을 활용하고자 한다면 조건에 맞는 데이터 프레임을 먼저 만들어주고

    2. 그 데이터 프레임 수를 파악하면 됩니다.

    3. df[조건] <- 조건에 맞는 행만 반환: df[df.loc[2000,:]>cond]

    4. 여기에 len(df[df.loc[2000,:]>cond])으로 감싸면 됩니다.

이해가 되었을까요?

아함님의 프로필 이미지
아함
질문자

오 그렇군요!

정말 감사드립니다 이해가 되었어요 ㅎㅎ

아함님의 프로필 이미지
아함

작성한 질문수

질문하기