해결된 질문
작성
·
367
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
안녕하세요:)
sum()함수 -> 합계
모든 값을 더하는 함수입니다.
df.loc[2000,:]>cond 만 출력을 해보면 행별로 조건에 맞으면 True, 아니면 False입니다.
True는 1, False는 0이에요
따라서 합계를 계산하면 조건에 만족하는 데이터 수를 구할 수가 있어요
len()함수 -> 데이터프레임에서는 행의 수를 구합니다.
만약 이 문제에서 len()을 활용하고자 한다면 조건에 맞는 데이터 프레임을 먼저 만들어주고
그 데이터 프레임 수를 파악하면 됩니다.
df[조건] <- 조건에 맞는 행만 반환: df[df.loc[2000,:]>cond]
여기에 len(df[df.loc[2000,:]>cond])으로 감싸면 됩니다.
이해가 되었을까요?
오 그렇군요!
정말 감사드립니다 이해가 되었어요 ㅎㅎ