std::match_results::size
C では、 std::match_results::size は一致した数を返す関数です。正規表現検索でのグループと全体の一致。見つかった一致の総数を返すわけではないことに注意することが重要です。
指定した例では、
<code class="cpp">#include <iostream> #include <string> #include <regex> int main() { std::string haystack("abcdefabcghiabc"); std::regex needle("abc"); std::smatch matches; std::regex_search(haystack, matches, needle); std::cout << matches.size() << std::endl; }</code>
matches.size() は 3 を返すと予想していましたが、代わりにこれは、regex_search が一致を 1 つだけ返し、size() がキャプチャ グループの数に一致の値全体を加えた値を返すためです。この場合、キャプチャ グループがないため、サイズは 1 (一致自体全体) です。
複数の一致を取得するには、std::regex_iterator を使用できます。これを次の代替コードで示します。
<code class="cpp">std::regex rgx1("abc"); int i = 0; smatch smtch; while (regex_search(str, smtch, rgx1)) { std::cout << i << ": " << smtch[0] << std::endl; i += 1; str = smtch.suffix().str(); }</code>
このコードは入力文字列を破棄するため、std::sregex_iterator:
<code class="cpp">std::regex r("ab(c)"); std::string s = "abcdefabcghiabc"; for(std::sregex_iterator i = std::sregex_iterator(s.begin(), s.end(), r); i != std::sregex_iterator(); ++i) { std::smatch m = *i; std::cout << "Match value: " << m.str() << " at Position " << m.position() << '\n'; std::cout << " Capture: " << m[1].str() << " at Position " << m.position(1) << '\n'; }</code>
を使用する別の代替案を示します。このイテレータベースのアプローチでは、元の文字列を維持しながら反復処理が可能です。
以上が正規表現検索で複数の一致に対して std::match_results::size が 3 ではなく 1 を返すのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。