我想在 Java 中创建一个正则表达式,它将匹配以下内容:
*A*B
其中 A 和 B 是除星号之外的任何字符,并且可以有任意数量的 A 字符和 B 字符。A(s) 前面有星号,B(s) 前面有星号。
下面的工作吗?当我运行它时似乎工作,但我想绝对确定。
Pattern.matches("\\A\\*([^\\*]{1,})\\*([^\\*]{1,})\\Z", someString)
我想在 Java 中创建一个正则表达式,它将匹配以下内容:
*A*B
其中 A 和 B 是除星号之外的任何字符,并且可以有任意数量的 A 字符和 B 字符。A(s) 前面有星号,B(s) 前面有星号。
下面的工作吗?当我运行它时似乎工作,但我想绝对确定。
Pattern.matches("\\A\\*([^\\*]{1,})\\*([^\\*]{1,})\\Z", someString)
它会起作用,但是您可以将其重写为(未引用):
\A\*([^*]+)\*([^*]+)\Z
{1,}
并且+
是相同的量词(一次或多次)。注意 1:您使用.matches()
which 自动将正则表达式锚定在开头和结尾;因此,您可以不使用\A
and \Z
。
注2:我保留了捕获组——你真的需要它们吗?
注3:不清楚是否要在星星之间重复相同的字符;上面的例子假设不是。如果你想要相同的,那么使用这个:
\A\*(([^*])\2*)\*(([^*])\4*)\Z
如果我做对了..它可以很简单
^\\*((?!\\*).)+\\*((?!\\*).)+
如果您想要匹配*AAA*BBB
但不*ABC*DEF
使用
^\*([a-zA-Z])\1*\*([a-zA-Z])\2*$
这也不匹配
*A_$-123*B<>+-321