Java正则表达式,用于验证数字逗号分隔值

Yar*_*nov 5 java regex csv numeric

我需要使用这些数字制作正则表达式:

 "+1", "1.0", "1,233", "1,233,456.34", "-1", ".34", "1,345,234,122,123"
Run Code Online (Sandbox Code Playgroud)

这些无效:

 "++1", "1.0.0", "1,23,3", "+-1233456.34", "002", "1.", "a1", "1,,2", "1 2", "1,2", ",2".
Run Code Online (Sandbox Code Playgroud)

我尝试了这个正则表达式的不同变体:

 "[\\+\\-]?[1-9]{0,3}([\\d]{3}[\\,]{1})?([\\d]{3}[\\,]{1})?([\\d]{3}[\\,]{1})?([\\d]{3}[\\,]{1})?([\\d]{3}[\\,]{1})?([\\.][\\d]*)?"
Run Code Online (Sandbox Code Playgroud)

测试代码:

import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class REGEX {
private static final String REGEX = "[\\+\\-]?[1-9]{0,3}([\\d]{3}[\\,]{1})?([\\d]{3}[\\,]{1})?([\\d]{3}[\\,]{1})?([\\d]{3}[\\,]{1})?([\\d]{3}[\\,]{1})?([\\.][\\d]*)?";

private static String[] validNumbers = { "+1", "1.0", "1,233",
        "1,233,456.34", "-1", ".34", "1,345,234,122,123" };

private static String[] invalidNumbers = { "++1", "1.0.0", "1,23,3",
        "+-1233456.34", "002", "1.", "a1", "1,,2", "1 2", "1,2", ",2" };

public static void main(String[] args) {
    Pattern pattern = Pattern.compile(REGEX);

    for (String number : validNumbers) {
        Matcher matcher = pattern.matcher(number);
        if (!matcher.matches()) {
            System.out.println("Valid number is detected as invalid: "
                    + number);
        }
    }
    for (String number : invalidNumbers) {
        Matcher matcher = pattern.matcher(number);
        if (matcher.matches()) {
            System.out.println("Invalid number is detected as valid: "
                    + number);
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

}

当控制台为空时,任务完成.现在我遇到了这样的问题:

有效号码被检测为无效:1,233

有效号码被检测为无效:1,233,456.34

有效号码被检测为无效:1,345,234,122,123

无效的数字被检测为有效:1.

问候.对不起大尺寸.

更新.感谢Noob UnChained,我已经进入了这个正则表达式:

^([\\+\\-]?[1-9]\\d{0,2})*(\\,\\d{3})*([\\.][\\d*])?$
Run Code Online (Sandbox Code Playgroud)

现在问题更少了:

有效号码被检测为无效:1,233,456.34

检测到有效号码无效:.34

更新.

正则表达式:

"([\\+\\-]?[1-9]\\d{0,2})*(\\,\\d{3})*([.][\\d]*)?"
Run Code Online (Sandbox Code Playgroud)

问题:

无效的数字被检测为有效:1.

FINISHED

最终结果是:

"(?!$)[\\+-]?([1-9]\\d{0,2}|0)?(\\,\\d{3})*(\\.\\d+)?"
Run Code Online (Sandbox Code Playgroud)

自上次更新以来的更改是:([.] [\ d] +)?

加上这个区块使得用户输入数字然后放入点而不是后面的任何内容都是不可能的情况.

新更新:在最后一个块中添加2"\"以避免输入逗号或其他符号而不是点.

新更新:感谢user2266098nhahtdh.

user2266098将注意力集中在"0.1"号的未知问题上,并显示了向第二个块添加"| 0"的解决方案.但是他的正则表达式与我的数据的"+"和" - "无法正常工作(因为"()"而不是"[]").我不喜欢量词"{0,}"而不是"*"因为它的大小.

nhahtdh将我的注意力集中在空字符串的未知问题上,并用"(?!$)"显示解决方案.

谢谢大家!

更新

这种情况有新的条件:

我需要使用这些数字制作正则表达式:

"+1", "1.0", "1,233", "1,233,456.34", "-1", ".34", "1,345,234,122,123", "0.1"
Run Code Online (Sandbox Code Playgroud)

这些无效:

"++1", "1.0.0", "1,23,3", "+-1233456.34", "002", "1.", "a1", "1,,2", "1 2", "1,2", ",2", "", "0,123"
Run Code Online (Sandbox Code Playgroud)

我仍然无法得到"完美"的regexp =)

"(?!$)[\\+-]?([1-9]\\d{0,2}|0)?(\\,\\d{3})*(\\.\\d+)?"
Run Code Online (Sandbox Code Playgroud)

给出:无效的数字被检测为有效:0,123

Yar*_*nov 4

完成的

最终结果是:

"(?!$)[\\+-]?([1-9]\\d{0,2}|0)?(\\,\\d{3})*(\\.\\d+)?"
Run Code Online (Sandbox Code Playgroud)

自上次更新以来的变化是:([.][\d]+)?

当用户输入数字然后添加点但其后不添加任何内容时,此块中的加号会出现不可能的情况。

新更新:在最后一个块中添加了 2 个“\”,以避免输入逗号或其他符号而不是点。

新更新:感谢user2266098nhahtdh

user2266098 将我的注意力集中在“0.1”数字的未知问题上,并展示了通过在第二个块中添加“|0”来解决方案。但他的正则表达式无法与我的数据的“+”和“-”一起正常工作。而且我不喜欢使用量词“{0,}”而不是“*”,因为它的大小。

nhahtdh 将我的注意力集中在未知的空字符串问题上,并用“(?!$)”显示了解决方案。

谢谢大家!

更新

本案有新的条件:

我需要使这些数字有效的正则表达式:

"+1", "1.0", "1,233", "1,233,456.34", "-1", ".34", "1,345,234,122,123", "0.1"
Run Code Online (Sandbox Code Playgroud)

这些无效:

"++1", "1.0.0", "1,23,3", "+-1233456.34", "002", "1.", "a1", "1,,2", "1 2", "1,2", ",2", "", "0,123"
Run Code Online (Sandbox Code Playgroud)

我仍然无法得到“完美”的正则表达式 =)

"(?!$)[\\+-]?([1-9]\\d{0,2}|0)?(\\,\\d{3})*(\\.\\d+)?"
Run Code Online (Sandbox Code Playgroud)

给出:无效数字被检测为有效:0,123