[英]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.