精度为2的小数的简单正则表达式

精度为2的小数的正则表达式是什么?

有效的例子:

123.12
2
56754
92929292929292.12
0.21
3.1

无效的例子:

12.1232
2.23332
e666.76

小数点可以是可选的,也可以包括整数。

712369 次浏览

有效的regex令牌因实现而异。一般形式是:

[0-9]+(\.[0-9][0-9]?)?

更紧凑的:

\d+(\.\d{1,2})?

两者都假设在小数点前和小数点后至少有一位数字。

要要求整个字符串都是这种形式的数字,可以将表达式包装在开始和结束标记中,例如(在Perl的形式中):

^\d+(\.\d{1,2})?$

要匹配小数点前没有前导数字(.12)的数字和结尾有句号(12.)的整数,同时排除单个句号(.)的输入,请尝试以下操作:

^(\d+(\.\d{0,2})?|\.?\d{1,2})$

添加

将小数部分包装在()?中,使其成为可选的。注意,这将排除诸如12.这样的形式,包括更像^\d+\\.?\d{0,2}$

添加

使用^\d{1,6}(\.\d{1,2})?$来停止重复,并对小数值的整个部分进行限制。

难道你不需要考虑e666.76中的e吗?

(e|0-9)\d*\d.\d{1,2)
^[0-9]+(\.[0-9]{1,2})?$

因为正则表达式读起来很可怕,更不用说理解了,这里是详细的等效:

^                         # Start of string
[0-9]+                   # Require one or more numbers
(                  # Begin optional group
\.                # Point must be escaped or it is treated as "any character"
[0-9]{1,2}      # One or two numbers
)?    # End group--signify that it's optional with "?"
$   # End of string

在大多数正则表达式实现中(包括最常见的PCRE),可以用\d替换[0-9]。我将它保留为[0-9],因为我认为它更容易阅读。

此外,这是我用来检查它的简单Python脚本:

import re
deci_num_checker = re.compile(r"""^[0-9]+(\.[0-9]{1,2})?$""")


valid = ["123.12", "2", "56754", "92929292929292.12", "0.21", "3.1"]
invalid = ["12.1232", "2.23332", "e666.76"]


assert len([deci_num_checker.match(x) != None for x in valid]) == len(valid)
assert [deci_num_checker.match(x) == None for x in invalid].count(False) == 0

要包含可选的负号,并禁止像015这样的数字(可能被误认为八进制数字),可以这样写:

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

试试这个

 (\\+|-)?([0-9]+(\\.[0-9]+))

它还允许正号和负号。

preg_match("/^-?\d+[\.]?\d\d$/", $sum)
我用这个来表示小数点后两位 (^(\+|\-)(0|([1-9][0-9]*))(\.[0-9]{1,2})?$)|(^(0{0,1}|([1-9][0-9]*))(\.[0-9]{1,2})?$) 传球:< br > 为< br > 0.25 < br > 10.25 < br > + 0.25 < br >
不通过:< br > 15年< br > 01.25 < br > 1。< br > 1.256 < br > < / p >
我在我的项目中尝试了一个。 这也允许带有+ | -符号的数字
/^(\+|-)?[0-9]{0,}((\.){1}[0-9]{1,}){0,1}$/

对于没有千位分隔符的数字,我喜欢这个简单、紧凑的正则表达式:

\d+(\.\d{2})?|\.\d{2}

或者,不限制在2的精度:

\d+(\.\d*)?|\.\d+

后者匹配
1 < br > 100年< br > 100年。< br > 100.74 < br > 100.7 < br > 0.7 < br > 7 < br > 开市< br > < / p >

并且它不匹配空字符串(像\d*.?\ d *会)

一般来说,即小数点后无限位:

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

^[0-9]+(\.([0-9]{1,2})?)?$

将使12.这样的东西被接受。这不是普遍接受的,但如果你需要“灵活”,这是一种方法。当然,[0-9]也可以用\d替换,但我想这样可读性更好。

加上我的答案,有人可能会觉得有用,也可能是对的。

function getInteger(int){
var regx = /^[-+]?[\d.]+$/g;
return regx.test(int);
}




alert(getInteger('-11.11'));

这招对我很管用:

(-?[0-9]+(\.[0-9]+)?)

组1是浮点数,而组2只是分数。

 function DecimalNumberValidation() {
var amounttext = ;
if (!(/^[-+]?\d*\.?\d*$/.test(document.getElementById('txtRemittanceNumber').value))){
alert('Please enter only numbers into amount textbox.')
}
else
{
alert('Right Number');
}
}

函数将验证任何十进制数字天气数字是否有小数点,它将说“正确的数字”,否则“请在数量文本框中只输入数字。”警报消息将出现。

谢谢……:)

Chrome 56不接受这种模式(Chrome 56接受11.11。一个附加的。)与类型数字,使用类型作为文本作为进度。

主答案是错误的,因为它有效的5.5,输入

这段代码处理了它(但在我的例子中,负数是禁止的):

/^[0-9]+([.,][0-9]{1,2})?$/;

结果如下:

< p >真的= > " 0 " /真的= >“0.00”/真的= >“0.0”/真的= >“0 00”/真实= > " 0 " /真的= >“1、2” 真的= >“1.1”/真的= > " 1 " /真的= >真正“100”= >“100.00”/真的= >“100.0”/真的= > “1.11”/真的= >“1、11”/错误= >“5”/错误= >“-0.00”/真的= > " 101 " /错误= > /真正= >“0.00.0 0.000”/真的= > " 000.25 " /假= > "。25" / true => "100.01" / 真的= >“100.2”/真的= >“00”/错误= >“5”。/ false => "6," / true => "82" / true => . "81,3" / true => "7" / true => "7.654"

.

这将允许小数取幂和最多2位,

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

Demo