inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

[퇴근후딴짓] 빅데이터 분석기사 실기 (작업형1,2,3)

[심화] 문자열

df2 replace 문의

해결된 질문

71

wsyang

작성한 질문수 48

0

df2['D'].replace(" ", "") 하는 것과

df2['D'].str.replace(" ", "") 하는 것이 어떤 차이가 있는것인가요?

 

str 붙이지 않았을 때는 공백 제거가 안되는데 어떤 차이가 있길래 두 함수 출력 값이 다른 것인가요?

python 머신러닝 빅데이터 pandas 빅데이터분석기사

답변 2

0

퇴근후딴짓

str.replace()와 replace()의 차이를 이해하는 핵심은 데이터 타입에 있습니다.

df2['D'].replace(" ", "")는 데이터프레임의 replace() 는 숫자형(int, float)일 경우에는 replace(4, 5)처럼 직접적으로 값을 대체할 수 있습니다.

하지만 문자열 내 특정 문자를 바꾸려면, 열을 문자열로 간주하여 .str.replace() 를 사용해야 합니다. str.replace()는 문자열 열에서만 작동하며, 문자열 열의 각 값 안에서 지정된 문자를 대체합니다.

 

 

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. wsyang님!

DataFrame에서 공백을 제거할 때 replace()str.replace()의 차이점을 물어보셨군요. 두 방법은 실제로 사용하는 방식이 조금 다르기 때문에 결과에서 차이가 생깁니다.

  • df2['D'].replace(" ", ""): 이 방식은 판다스의 replace() 함수로, 일반적으로 전체 값을 교체할 때 사용됩니다. 예를 들어, 특정 값을 다른 값으로 직접적으로 변경할 수 있습니다. 하지만 공백 제거와 같은 세밀한 문자열 조작에는 적합하지 않습니다. 따라서 이 방식으로는 공백이 제거되지 않을 것입니다.

  • df2['D'].str.replace(" ", ""): str.replace() 메소드는 문자열 조작을 위한 판다스의 StringMethods 클래스의 기능입니다. 여기서 .str을 사용하면 각 요소가 문자열로 처리되어, 문자열 내의 특정 패턴(공백 포함)을 찾고 변경할 수 있게 됩니다. 따라서 이 방식은 문자열 내부에서 공백을 제거하는 데 적합합니다.

이러한 차이에 대해 더 알고 싶다면 아래의 링크에서 관련된 토론을 확인하실 수 있습니다:
- df.replace()와 df.str.replace()의 차이

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

작업형 1 유형 부분

0

13

1

작업형 1 (삭제예정, 구 버전)

0

34

2

수강기간 연장 문의드립니다.

0

24

1

2유형 레이블 인코딩 VS 원핫 인코딩

0

25

3

수강기간 연장 문의드립니다.

0

27

1

인덱스 슬라이싱

0

28

2

질문 드립니다.

0

46

2

강의 내용 관련 질문드립니다~

0

43

2

수강 연장 문의

0

56

2

강의자료 일괄 다운로드

0

52

2

수강기간 연장 문의드립니다

0

41

2

list 문제 질문드립니다~

0

35

2

빅분기 실기 12회 재도전

0

54

2

강의 기간 연장 가능여부 검토 요청건

0

39

2

수강기간 연장 문의 드립니다

0

43

2

수강기간 연장 문의드립니다

0

50

2

질문이요

0

56

2

수강기간 연장 문의드립니다.

0

58

2

문제 3-2 질문드립니다

0

47

2

수강기간 연장 문의 드립니다.

0

61

2

변수, 칼럼 , df 구분

0

51

2

수강기간 연장 문의드립니다.

0

50

2

수강기간 연장 문의

0

49

2

수강기간 연장 문의드립니다.

0

42

2