Data/Data Analysis

[Pandas] apply, map, groupby등 모르는거 정리

재융 2020. 11. 4. 18:14
반응형

Apply

pyspark 에서 udf성격을 띄는 pandas function 이다.

 

# 한 컬럼만 적용할 경우
def stars(values):
	if values >= 95:
    	return 3
    elif values >= 85:
    	return 2
    else:
    	return 1
        
df.values.apply(stars)

# 여러 컬럼이 필요할 경우
def stars(df):
	if df.country == 'canada':
    	return 3
    elif df.score >= 95:
    	return 3
    elif df.score >= 85:
    	return 2
    else:
    	return 1
        
df.apply(stars, axis='columns')

Map

위처럼 함수를 사용하지않고 한줄의 코드로도 작성이 가능하다

# 만일 한 column에서 평균 값을 뺀 결과를 얻고싶다면...
# df Dataframe
#+------+
#|score |
#+------+
#|     1|
#|     2|
#|     3|
#+------+

avg_score = df.score.mean()
result = df.score.map(lambda x: x - avg_score)
# 사실 이 연산은
# df.score - df.score.mean() 이랑도 같은 결과가나온다

"""
결과는
-1
0
1
"""

value_counts()

특정 column에서 해당 값이 얼마나 나왔는지 확인용 함수

"""
데이터프레임 df에 특정컬럼(score)안에
1
1
1
3
3
3
2
2
가 있다고 할때
"""

df.score.value_counts()

"""
1 -> 3
3 -> 3
2 -> 2
score별로 개수를 세어줄수가있다
"""

groupby()

특정 그룹을 이뤄서 연산을 할때 사용하는 함수

# 특정 그룹의 한개의 컬럼만 계산하고싶을떄
df.groupby('column1')['column2'].mean()

# 특정 그룹의 여러개 컬럼을 계산해야할때(ex. 어떤건 카운트 어떤건 평균값이 필요할때
df_after = df.groupby('column1').agg({'column2':'count', 'column3':'mean'})

# df_after가 dataframe을 보면 index들이 좀 이상한 위치에 있는데 이걸 바로잡으려면
df_after.reset_index()

replace()

Dataframe에서 특정 값들을 변경하고싶을때

- 변경전

- 변경후

반응형