Biblioteca C ++ Regex - regex_search
Descripción
Devuelve si alguna subsecuencia en la secuencia de destino (el sujeto) coincide con la expresión regular rgx (el patrón). La secuencia de destino es s o la secuencia de caracteres entre el primero y el último, según la versión utilizada.
Declaración
A continuación se muestra la declaración de std :: regex_search.
template <class charT, class traits>
bool regex_search (const charT* s, const basic_regex<charT,traits>& rgx,
regex_constants::match_flag_type flags = regex_constants::match_default);
C ++ 11
template <class charT, class traits>
bool regex_search (const charT* s, const basic_regex<charT,traits>& rgx,
regex_constants::match_flag_type flags = regex_constants::match_default);
C ++ 14
template <class charT, class traits>
bool regex_search (const charT* s, const basic_regex<charT,traits>& rgx,
regex_constants::match_flag_type flags = regex_constants::match_default);
Parámetros
s - Es una cadena con la secuencia objetivo.
rgx - Es un objeto basic_regex para que coincida.
flags - Se utiliza para controlar cómo se empareja rgx.
m - Es un objeto de tipo match_results.
Valor devuelto
Devuelve verdadero si rgx coincide con una subsecuencia en la secuencia objetivo. falso de lo contrario.
Excepciones
No-noexcept - esta función miembro nunca arroja excepciones.
Ejemplo
En el siguiente ejemplo para std :: regex_search.
#include <iostream>
#include <string>
#include <regex>
int main () {
std::string s ("this subject has a submarine as a subsequence");
std::smatch m;
std::regex e ("\\b(sub)([^ ]*)");
std::cout << "Target sequence: " << s << std::endl;
std::cout << "Regular expression: /\\b(sub)([^ ]*)/" << std::endl;
std::cout << "The following matches and submatches were found:" << std::endl;
while (std::regex_search (s,m,e)) {
for (auto x:m) std::cout << x << " ";
std::cout << std::endl;
s = m.suffix().str();
}
return 0;
}
La salida debería ser así:
Target sequence: this subject has a submarine as a subsequence
Regular expression: /\b(sub)([^ ]*)/
The following matches and submatches were found:
subject sub ject
submarine sub marine
subsequence sub sequence