我有这个正则表达式"^[0-9]+\.?[0-9]*$")来匹配visual c ++中的双数或整数,但它似乎不起作用.有任何想法吗.这就是我应用代码的方式:
if ( System::Text::RegularExpressions::Regex::IsMatch(e0, "^[0-9]+\.?[0-9]*$"))
{
e0_val = System::Convert::ToDouble(e0);
}
Run Code Online (Sandbox Code Playgroud)
Tha*_*sMe 16
上面的正则表达式并不完美,因为它接受不是有效数字的“09”。更好的表达是:
"^(-?)(0|([1-9][0-9]*))(\\.[0-9]+)?$"
Run Code Online (Sandbox Code Playgroud)
在哪里:
1. is an optional negative sign;
2. is zero or a valid non-zero integer;
4. is the optional fracture part;
Run Code Online (Sandbox Code Playgroud)
理论上,断裂部分应该写成“(\.[0-9]*[1-9])?” 相反,因为数字不能有尾随零。实际上,源字符串可能是用固定数量的数字创建的,例如:
printf("%.1f", x);
Run Code Online (Sandbox Code Playgroud)
所以它可能很容易以零字符结尾。当然,这些都是定点表示,而不是双打本身。双数也可以写为 -1.23e-4 而不是 -0.000123。
Ben*_*enj 12
每个人说的正则表达式没有任何问题,这是你的逃避错误.你需要双重转义\字符,因为那也是一个C++字符串转义字符.
另外还有一个边缘情况,这个正则表达式会认为这1.是一个有效的浮动指针号.所以你可能会更好,/^[0-9]+(\\.[0-9]+)?$从而消除了这种可能性.
也许不是直接答案,只是有用的信息。正则表达式:
std::regex rx(R"(^([+-]?(?:[[:d:]]+\.?|[[:d:]]*\.[[:d:]]+))(?:[Ee][+-]?[[:d:]]+)?$)");
Run Code Online (Sandbox Code Playgroud)
匹配字符串:
"1", "0", "10",
"1000.1", "+1",
"+10", "-10", "1.",
".1", "1.1", "+1.",
"-1.", "+.1", "-.1",
"009", "+009", "-009",
"-01e0", "+01E0", "+1e-1",
"+1e+1", "+1.e1", "1E1",
"1E+1", "0.001e-12", "0.111111111111111"
Run Code Online (Sandbox Code Playgroud)
并且不匹配接下来的字符串:
".", "1a", "++1",
"+-1", "+", "-.",
"-", "--1.", "1.e.1",
"1e.1", "0+.e0"
Run Code Online (Sandbox Code Playgroud)
double第一个看起来像C++ 中类型的有效值,例如double test = +009.e+10OK。
在 ideone.com 中播放:https ://ideone.com/ooF8sG