Pandas 연습문제 4. apply 활용 질문
562
投稿した質問数 8
안녕하세요, 학습하다가 이해가 되지 않는 부분이 있어 질문드립니다!
4. apply 활용
각 행에 대해 남성 인구의 합을 구하여 남자인구 합계 이름을 가진 컬럼을 생성해주세요.
위 문제에서,
def getManPopulation(row):
man = 0
for i in row.index:
if "남자" in i:
man += row[i]
return man
sample['남자인구 합계'] = sample.apply(getManPopulation, axis=1)
sample.head()
getManPopulation(row):
여기 row자리에 데이터프레임(sample)이 들어간다고 생각하면
for i in row.index의 row.index가 위에서 index로 설정해놓은 '일자' 컬럼이 될텐데 어떻게 if "남자" in i가 성립되는건가요?
밑에서 row[i]를 사용하는 거 보면 row는 데이터프레임이고 i는 컬럼명이 맞는 것 같은데 이해가 되지 않아 질문드립니다.
감사합니다!
回答 1
1
row.index는
남자0~9세남자10~14세남자15~19세남자20~24세남자25~29세남자30~34세...여자45~49세여자50~54세여자55~59세여자60~64세여자65~69세여자70~74세여자75~79세
이런식으로 데이터프레임 컬럼입니다.
if "남자" in i 는 컬럼명에 '남자'라는 문자열이 포함되어 있는지 검사합나다.
row[i]는 row의 value를 의미합니다. 즉, 인구수를 의미하게 됩니다.
추가적으로 row는 apply 함수를 통해 적용되는데이터프레임의 행입니다. 시리즈형 데이터라고 표현하는 것이 바른 표현입니다!
감사합니다.
0
row를 데이터프레임 그 자체로 착각하고 있었네요! 데이터프레임의 행이자 시리즈형 데이터라고 말씀해주시니 이해했습니다 ㅎㅎ
매번 빠르고 친절한 설명 감사드립니다.
늘 컴퓨터를 켜두어야 하는 것에 대한 질문입니다.
0
8
1
MMDetection 버전 이슈
0
9
2
1유형 강의 다 나간 후 어떻게 할까요?
0
12
1
점수차가 많이 나는데 따로 하신게 있으신가요?
0
8
1
노션 승인 관련
0
20
3
만세력 계산 오류 및 결과 오류
0
26
2
한글 변수의 한글 상태를 만드는 법?
0
18
0
작업형1 모의문제 4번에 3)문제 질문
0
18
2
강의 수강 순서
0
20
1
coders 사이트 로그인이 안돼요
0
25
2
호스트 테스트 주소 복사?
0
21
1
이상치 전처리 작업
0
25
2
명령팔레트에서 오류
0
38
3
평가결과값 문의
0
28
2
Sonauto V2 text to audio
0
23
2
Part2 자료에 대한 질문입니다.
0
28
3
시계열 데이터 날짜와 시간 format
0
34
2
자동화 프로그램 프로젝트
0
23
1
파이썬 연습문제 6번 관련 문의
0
62
1
divide 함수 축 질문
0
60
1
쥬피터노트북이 안깔려요
0
456
1
pandas 연습문제 4번 관련
0
355
1
마크다운 blank line
0
813
1
내국인 생활인구.csv 다운위치
0
602
1

