繁体   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