Regex 일치 후 텍스트 검색
Regex를 효과적으로 사용하려는 과정에서 일치하는 패턴에 따라 텍스트를 추출하는 문제에 직면했습니다. . 해결책을 자세히 살펴보겠습니다.
원래 Regex 패턴인 "sentence(.*)"가 목표를 거의 달성했습니다. 그러나 일치하는 문자열("문장")과 후속 텍스트를 모두 무차별적으로 캡처합니다. 이를 수정하려면 "lookbehind 어설션"이라는 개념을 도입해야 합니다.
Lookbehind Assertion 사용
긍정적인 Lookbehind 어설션(?<=. ..)는 주어진 표현식 바로 뒤의 문자열에서 특정 위치와 일치합니다. 이 경우 문자열 "sentence" 바로 뒤의 위치를 일치시키려고 합니다.
(?<=sentence).*
이 패턴은 "'sentence' 바로 앞에 오는 위치 뒤에서 0개 이상의 문자를 일치시킵니다."로 읽습니다. 따라서 원하는 텍스트를 성공적으로 추출했습니다.
Java에서 구현
이를 Java에서 구현하려면 다음과 같이 코드를 수정하면 됩니다.
Pattern pattern = Pattern.compile("(?<=sentence).*"); Matcher matcher = pattern.matcher("some lame sentence that is awesome"); boolean found = false; while (matcher.find()) { System.out.println("I found the text: " + matcher.group().toString()); found = true; } if (!found) { System.out.println("I didn't find the text"); }
이제 정규식을 입력 문자열에 적용하면 "문장" 다음 텍스트만 일치하여 인쇄합니다.
I found the text: that is awesome
위 내용은 Lookbehind 어설션을 사용하여 정규식 일치 후 텍스트를 추출하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!