>백엔드 개발 >C++ >C의 std::regex를 사용하여 문자열의 모든 단어를 어떻게 일치시킬 수 있습니까?

C의 std::regex를 사용하여 문자열의 모든 단어를 어떻게 일치시킬 수 있습니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-11 08:54:09740검색

How Can I Match All Words in a String Using C  's std::regex?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.