这可能是一个相当微不足道的问题,但我对Regex如何在C ++中工作感到困惑。我有一个如下所示的文本文件:
Weapons: Cost Damage Armor
Dagger 8 4 0
Shortsword 10 5 0
Warhammer 25 6 0
Longsword 40 7 0
Greataxe 74 8 0
我想在结构中存储每个武器的名称,成本,伤害和护甲。我尝试使用以下代码执行此操作:
regex rule("(\\w+)\s(\\w+)\s(\\w+)\s(\\w+)");
smatch match;
for (int i = 0; i < 6; i++) {
if (regex_match(lines[i], match, rule)) {
struct Weapon Weapon;
Weapon.Name = match[1];
Weapon.Cost = stoi(match[2], NULL, 10);
Weapon.Damage = stoi(match[3], NULL, 10);
Weapon.ArmorValue = stoi(match[4], NULL, 10);
Weapons.push_back(Weapon);
}
}
但if语句总是返回false。
我是否错误地使用了正则表达式规则?
我应该如何使用Regex将该表中的数据存储在结构中?
答案 0 :(得分:5)
首先,我认为你的正则表达式应该更像这样:
(\\ W +)\\ S +(\\ W +)\\ S +(\\ W +)\\ S +(\\ W +)
你刚刚失去了空间。
现在只需迭代数组并记住第一个第零个匹配
“Dagger 8 4 0”(带空格)
编辑: 下一场比赛如下:
匹配[1] =“匕首”
匹配[2] =“8”
匹配[3] =“4”
匹配[4] =“0”
这是我的测试代码:
std::string data = "Dagger 8 4 0";
std::regex rule("(\\w+)\\s+(\\w+)\\s+(\\w+)\\s+(\\w+)");
std::smatch match;
if (regex_match(data, match, rule)) {
std::cout << match[0] << std::endl << match[1] << match[2] << match[3] << match[4] << std::endl;
}
编辑2: 就个人而言,我宁愿使用\ d而不是\ w,这就是原因:
让我们假设其中一行看起来像这样: “匕首3 3字”
使用\ w将取'word'并且regex_match现在返回true,假设您的Weapon.ArmorValue是某种数值数据,此char *将转换为此数值并且数据将不会处于良好状态。(* )
然而,使用\ d会使你的regex_match返回false,因为'word'不是数字。 当然我认为那些是整数(双精度和浮点数需要像\ d +。\ d +这样的正则表达式) 因此,你的正则表达式现在看起来像这样:
(\ W +)\ S +(\ d +)\ S +(\ d +)\ S +(\ d +)
(*)或者更糟糕的是 - 它可能引发一些异常,这可能会导致程序停止。