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