这可能是一个相当简单的问题,但我对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将该表中的数据存储在结构中?
首先,我认为你的正则表达式应该更像这样:
(\\ w +)\\ s +(\\ w +)\\ s +(\\ w +)\\ s +(\\ w +)
你刚刚失去了空间.
现在只需迭代数组并记住第一个第零个匹配是"Dagger 8 4 0"(带空格)
编辑:下一场比赛如下:
match [1] ="Dagger"
match [2] ="8"
match [3] ="4"
match [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,这就是为什么:
让我们假设其中一条线看起来像这样:"Dagger 3 3字"
使用\ w将使用'word'并且regex_match现在返回true,假设您的Weapon.ArmorValue是某种数值数据,此char*将转换为此数值并且数据将不会处于良好状态.(*)
但是使用\ d会使你的regex_match返回false,因为'word'不是数字.当然我认为那些是整数(双精度和浮点数需要像\ d +.\ d +这样的正则表达式)因此你的正则表达式现在看起来像这样:
(\ W +)\ S +(\ d +)\ S +(\ d +)\ S +(\ d +)
(*)或者甚至更糟 - 它可能引发一些异常,这可能导致程序停止.