Próbuję wyodrębnić submikoty z pliku tekstowego za pomocą doładowania regex. Obecnie zwracam tylko pierwszą prawidłową linię i pełną linię zamiast prawidłowego adresu e-mail. Próbowałem używać iteratora i używania submatches, ale nie miałem z nim powodzenia. Oto aktualny kod:Wyodrębnianie submatów przy użyciu regex doładowania w języku C++
if(Myfile.is_open()) {
boost::regex pattern("^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a-z0-9-]+)*(\.[a-z]{2,4})$");
while(getline(Myfile, line)) {
string::const_iterator start = line.begin();
string::const_iterator end = line.end();
boost::sregex_token_iterator i(start, end, pattern);
boost::sregex_token_iterator j;
while (i != j) {
cout << *i++ << endl;
}
Myfile.close();
}
Być może mój Regeks jest w błędzie, ale to nie przynosi właściwych wyników. – John
Czy regex, dzięki. – John