/ / Parse čísla podľa bodky so std :: regex [duplicate] - c ++, regex, parsovanie

Parse numbers by dot s std :: regex [duplicate] - c ++, regex, parsovanie

Snažím sa analyzovať čísla oddelené bodkami a dostať každé číslo ako samostatný reťazec. To je môj vzorový program:

#include <iostream>
#include <string>
#include <regex>

int main(int argc, char* argv[])
{
try
{
std::string data("123.321.456.654");
std::regex reg(R"(([0-9]+).(1).(1).(1))");
std::smatch m;
if (std::regex_match(data, m, reg))
{
std::cout << m.size() << std::endl;
//std::cout << m[0].str() << std::endl;
std::cout << m[1].str() << std::endl;
std::cout << m[2].str() << std::endl;
std::cout << m[3].str() << std::endl;
std::cout << m[4].str() << std::endl;
}
}
catch (const std::exception& e)
{
std::cerr << "Error occurred: " << e.what() << std::endl;
}

return EXIT_SUCCESS;
}

V tejto vzorke používam tri regex:

funguje:

std::regex reg(R"((d+).(d+).(d+).(d+))");

funguje:

std::regex reg(R"(([0-9]+).([0-9]+).([0-9]+).([0-9]+))");

nefungujú vôbec:

std::regex reg(R"(([0-9]+).(1).(1).(1))");

Moja otázka je, prečo posledný regex nefunguje a kde je chyba v syntaxi? Vďaka.

odpovede:

0 pre odpoveď č. 1

Chyba nie je vo vašej syntaxi; je to vo vašej logike.

Spätné odkazy neopakujú vzor; zhodujú sa s predtým zhodným textom.

Takže váš vzor by sa zhodoval 123.123.123.123.