我尝试了以下正则表达式:
const static char * regex_string = "([a-zA-Z0-9]+).*";
void find_first(const std::string str);
int main(int argc, char ** argv)
{
find_first("0s7fg9078dfg09d78fg097dsfg7sdg\r\nfdfgdfg");
}
void find_first(const std::string str)
{
std::cout << str << std::endl;
std::regex rgx(regex_string);
std::smatch matcher;
if(std::regex_match(str, matcher, rgx))
{
std::cout << "Found : " << matcher.str(0) << std::endl;
} else {
std::cout << "Not found" << std::endl;
}
}
我本来期望正则表达式完全正确并且可以找到组。但它没有。为什么?如何在C++正则表达式中匹配换行符?在Java中它很好用。
$
。 - πάντα ῥεῖ(.|\r\n)*
来匹配,而不是使用.*
吗? - Zereges