Pandas replacement() 메서드가 작동하지 않나요? 이 간단한 수정을 시도해 보세요
replace() 메서드를 사용하여 Pandas DataFrame 내에서 문자열을 바꾸려고 할 때 대체가 발생하지 않는 당황스러운 문제가 발생할 수 있습니다. 복잡한 교체와 달리 이 상황에는 간단한 교체 시도가 포함되는 경우가 많습니다.
설명을 위해 다음 데이터프레임을 살펴보겠습니다.
d = {'color' : pd.Series(['white', 'blue', 'orange']), 'second_color': pd.Series(['white', 'black', 'blue']), 'value' : pd.Series([1., 2., 3.])} df = pd.DataFrame(d)
모든 'white' 항목을 다음으로 바꾸려고 할 때 NaN, 놀랍게도 아무 일도 일어나지 않습니다.
df.replace('white', np.nan)
출력은 변경되지 않고 그대로 유지됩니다.
color second_color value 0 white white 1 1 blue black 2 2 orange blue 3
그럼 무엇이 잘못되었나요?
replace() 메소드는 기본적으로 전체 대체 검색을 수행합니다. 부분 교체를 활성화하려면 정규식 매개변수를 True로 설정해야 합니다.
df.replace('white', np.nan, regex=True)
또는 교체 프로세스를 더 효과적으로 제어할 수 있는 str.replace() 메서드를 사용할 수 있습니다.
df['color'].str.replace('white', np.nan)
보너스 팁: inplace=True를 사용하여 내부 교체를 수행하려는 경우 주의 사항을 이해해야 합니다.
위 내용은 내 Pandas `replace()` 메서드가 간단한 문자열 교체에 작동하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!