안녕하세요! sum 함수를 쓸 곳에 len을 썼다가 의문이 생겨서 질문드립니다!
안녕하세요, 좋은 강의 잘 듣고 있습니다!
다름이 아니라 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])으로 감싸면 됩니다.
이해가 되었을까요?
평가결과값 문의
0
2
1
시계열 데이터 날짜와 시간 format
0
15
1
평가지표 F1 스코어 질문드립니다.
0
16
2
작업형 2 기출7회분에서
0
32
2
작업형2 모의문제1 (30강)
0
28
2
수강 기간 연장 문의 드립니다.
0
35
2
수강 계획과 관련해 문의 드립니다.
0
26
2
작업형1 - 연습문제 16~39 풀이는 몇강을 보면 되나요?
0
49
2
작업형 1 -연습문제 4-6
0
35
2
작업형 1 유형 부분
0
42
2
작업형 1 (삭제예정, 구 버전)
0
51
2
수강기간 연장 문의드립니다.
0
37
2
2유형 레이블 인코딩 VS 원핫 인코딩
0
37
3
수강기간 연장 문의드립니다.
0
44
2
인덱스 슬라이싱
0
36
2
질문 드립니다.
0
50
2
강의 내용 관련 질문드립니다~
0
46
2
수강 연장 문의
0
63
2
강의자료 일괄 다운로드
0
58
2
수강기간 연장 문의드립니다
0
48
2
list 문제 질문드립니다~
0
38
2
빅분기 실기 12회 재도전
0
63
2
강의 기간 연장 가능여부 검토 요청건
0
51
2
수강기간 연장 문의 드립니다
0
46
2





