簡體   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