繁体   English   中英

Java USSD代码正则表达式模式

[英]Java USSD code regex pattern

如何测试字符串是否是有效的ussd代码? 我试图编写自己的正则表达式但失败了。

它应该以*符号开头,后跟任何整数或另一个* 星形符号不能重复。 一定不能 ** 最后一个符号必须是# 此符号也允许一次。

我的测试:

public static final Pattern USSD = Pattern.compile("Pattern here");

System.out.println(USSD.matcher("*123#").matches());     // Must be true
System.out.println(USSD.matcher("*1*2*3#").matches());   // Must be true
System.out.println(USSD.matcher("*1#23#").matches());    // Must be false
System.out.println(USSD.matcher("***123###").matches()); // Must be false
System.out.println(USSD.matcher("*12**3#").matches());   // Must be false

我已经尝试过的:

  • 这个答案不是我想要的。 它允许双*和双#
  • ^\\*([0-9]|\\*?)*#$对双星没有帮助

您可以使用以下正则表达式matches()

(?:\*\d+)+#

请参阅正则表达式演示

在Java中,将其声明为

String pattern = "(?:\\*\\d+)+#";

图案细节

  • ^ - (隐含在matches() ) - 字符串的开头
  • (?:\\*\\d+)+ - 出现1次或多次模式序列:
    • \\* - 一个* char
    • \\d+ - 1+位数
  • $ - (隐含在matches() ) - 字符串结尾。

Java演示

List<String> strs = Arrays.asList("*123#","*1*2*3#","*1#23#","***123###","*12**3#");
Pattern pat = Pattern.compile("(?:\\*\\d+)+#");
for (String str : strs) {
    System.out.println(str + ": " + pat.matcher(str).matches());
}

输出:

*123#: true
*1*2*3#: true
*1#23#: false
***123###: false
*12**3#: false

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM