std::regex를 사용하여 여러 결과 일치
이 문서에서는 사용자가 다음을 사용하여 주어진 문자열의 모든 단어를 일치시키려고 시도하는 시나리오에 대해 설명합니다. C 표준 라이브러리 정규식 엔진(std::regex). 사용자는 이를 달성하기 위해 정규식 패턴 "(bS*b)"를 사용하지만 예상치 못한 동작에 직면합니다.
문제
제공된 초기 정규식 패턴은 "( bS*b)"는 단어 경계(b)와 공백이 아닌 문자(S)로 묶인 단어를 캡슐화합니다. 그러나 regex_search 함수와 결합하면 이 패턴은 입력 문자열 내의 여러 잠재적 일치 항목을 설명하지 못합니다.
해결책
이 문제를 해결하려면 다음을 수행하십시오. regex_search를 지속적으로 적용하면서 입력 문자열을 반복하는 데 필요합니다. 이렇게 하면 모든 일치 항목을 감지하고 캡처할 수 있습니다. 아래 수정된 코드는 이 접근 방식을 보여줍니다.
{ regex exp("(\b\S*\b)"); smatch res; string str = "first second third forth"; string::const_iterator searchStart( str.cbegin() ); while ( regex_search( searchStart, str.cend(), res, exp ) ) { cout << ( searchStart == str.cbegin() ? "" : " " ) << res[0]; searchStart = res.suffix().first; } cout << endl; }
이 수정된 코드에서는 반복자 searchStart가 입력 문자열의 시작 부분으로 초기화됩니다. regex_search 함수는 searchStart를 검색 시작 위치로 사용하여 반복적으로 호출됩니다. 일치하는 항목이 발견되면 일치 항목이 인쇄되고 searchStart가 일치하는 텍스트 다음의 위치로 조정됩니다. 더 이상 일치하는 항목을 찾을 수 없을 때까지 이 프로세스가 계속됩니다.
위 내용은 C의 std::regex를 사용하여 문자열의 모든 단어를 어떻게 일치시킬 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!