re.match와 re.match의 주요 차이점 이해
Python의 re 모듈에서 match() 및 search() 함수 패턴 매칭에서 서로 다른 역할을 합니다. 주요 차이점은 앵커 포인트에 있습니다.
re.match
match() 함수는 입력 문자열의 시작 부분에 패턴이 있는지 확인합니다. 문자열의 나머지 부분은 고려하지 않으므로 일치가 처음에만 발생하도록 보장합니다. 즉, 패턴이 문자열의 다른 곳에 나타나더라도 re.match는 결과를 반환하지 않습니다.
re.search
반면에 re.search는 검사합니다. 전체 입력 문자열을 검색하여 패턴이 나타나는지 찾습니다. 문자열 내 어디에서나 패턴이 발견되면 일치 개체를 반환합니다. 이 함수는 문자열을 시작하는 데 패턴이 필요하지 않으므로 re.match보다 덜 제한적입니다.
주요 고려 사항
사용할 함수를 선택할 때 다음을 고려하세요. 다음은 다음과 같습니다.
실제 사례
차이점이 있다면 다음 문자열을 고려해 보겠습니다.
"This is a sentence with multiple words."
"This" 패턴과 함께 re.match를 사용하면 성공하고, 문자열 시작 부분에 "This"가 나타나므로 re.search를 사용하면 성공합니다. 그러나 "with" 패턴을 검색하면 "with"는 문자열을 시작하지 않기 때문에 re.search만 결과를 반환합니다.
이제 개행 문자가 있는 문자열을 고려해 보겠습니다.
"Line 1\nLine 2"
re.match("^Line 2", string, re.MULTILINE)를 사용하면 "^"이 문자열의 시작 부분에 고정되고 다음 이후에는 일치하지 않기 때문에 실패합니다. 개행. 그러나 re.search("^Line 2", string, re.MULTILINE)는 re.search에 동일한 위치 제약 조건이 없기 때문에 성공합니다.
위 내용은 Python의 `re.match`와 `re.search`의 주요 차이점은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!