簡體   English   中英

Java正則表達式模式匹配

[英]Java Regular Expression Pattern Matching

我想用Java創建一個正則表達式,該正則表達式將匹配以下內容:

* A * B

其中A和B是除星號之外的任何字符,並且可以有任意數量的A字符和B字符。 A(s)之前帶有星號,B(s)之前帶有星號。

請問以下工作? 運行它時似乎可以正常工作,但是我想絕對確定。

Pattern.matches("\\A\\*([^\\*]{1,})\\*([^\\*]{1,})\\Z", someString)

它將起作用,但是您可以將其重寫為以下形式(未引用):

\A\*([^*]+)\*([^*]+)\Z
  • 無需在字符類中引用星號;
  • {1,}+是相同的量詞(一次或多次)。

注意1:您使用.matches()會自動將正則表達式錨定在開頭和結尾; 因此,您可能沒有\\A\\Z

注意2:我保留了捕獲組-您是否真的需要它們?

注3:不清楚是否要在星星之間重復相同的字符; 上面的示例假設不是。 如果您要相同,請使用以下命令:

\A\*(([^*])\2*)\*(([^*])\4*)\Z

如果我正確的話..它可以很簡單

^\\*((?!\\*).)+\\*((?!\\*).)+

如果要在*AAA*BBB上匹配但在*ABC*DEF上不匹配

^\*([a-zA-Z])\1*\*([a-zA-Z])\2*$

這也不會匹配

*A_$-123*B<>+-321

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM