我根本没用过正则表达式,所以在故障排除方面遇到了困难。我想正则表达式匹配仅当包含的字符串是所有数字;但是在下面两个例子中,它匹配的是一个包含所有数字加上等号的字符串,比如“1234=4321”。我确信有一种方法可以改变这种行为,但正如我所说的,我从来没有真正使用过正则表达式。

string compare = "1234=4321";
Regex regex = new Regex(@"[\d]");

if (regex.IsMatch(compare))
{ 
    //true
}

regex = new Regex("[0-9]");

if (regex.IsMatch(compare))
{ 
    //true
}

以防万一,我使用的是c#和。net 2.0。


当前回答

下面是我的工作:

^(-?[1-9]+\\d*([.]\\d+)?)$|^(-?0[.]\\d*[1-9]+)$|^0$

还有一些测试

积极的测试:

string []goodNumbers={"3","-3","0","0.0","1.0","0.1","0.0001","-555","94549870965"};

负面测试:

string []badNums={"a",""," ","-","001","-00.2","000.5",".3","3."," -1","--1","-.1","-0"};

不仅检查了c#,还检查了Java、Javascript和PHP

其他回答

也许我的方法对你有帮助。

    public static bool IsNumber(string s)
    {
        return s.All(char.IsDigit);
    }

如果你需要容忍小数点和千位标记

var regex = new Regex(@"^-?[0-9][0-9,\.]+$");

如果数字可以变成负数,你需要一个“-”。

 console.log(/^(0|[1-9][0-9]*)$/.test(3000)) // true

下面的正则表达式只接受英语和阿拉伯语(波斯语)语言中的数字(也是浮点数)(就像Windows计算器一样):

^((([0\u0660\u06F0]|([1-9\u0661-\u0669\u06F1-\u06F9][0\u0660\u06F0]*?)+)(\.)[0-9\u0660-\u0669\u06F0-\u06F9]+)|(([0\u0660\u06F0]?|([1-9\u0661-\u0669\u06F1-\u06F9][0\u0660\u06F0]*?)+))|\b)$

上面的正则表达式接受以下模式:

11
1.2
0.3
۱۲
۱.۳
۰.۲
۲.۷

上述正则表达式不接受以下模式:

3.
.3
0..3
.۱۲

对不起,格式很难看。 对于任意位数:

[0-9]*

对于一个或多个数字:

[0-9]+