所以,我正在开发一个程序,我需要在其中检查一个字符串是否有多个点。我去查看了 regex
的文档,发现了这个:
X{n,m}? X, at least n but not more than m times
按照这个逻辑我尝试了这个:
mString = "He9.lo,"
if (myString.matches(".{1,2}?")){
System.out.print("it works");
}
但这不起作用(它不会给出任何错误,它只是不会执行 if
中的操作)。我认为问题在于认为点意味着别的东西。我也看了这个问题:regex但适用于 php,我不知道如何将其应用于 java。
编辑:基本上我想知道一个字符串是否包含多个点,例如:
He......lo(True,包含多个),hel.llo(False,包含一个),..hell.o(True 包含多个)
如有任何帮助,我们将不胜感激。
最佳答案
正则表达式中的点表示“任何字符”。因此,如果您想要实际的点,您需要使用反斜杠对其进行转义 - 然后您需要在 Java 本身中对反斜杠进行转义...
if (myString.matches("\\.{1,2}?")){
接下来您需要了解匹配
试图匹配整个 文本——它不仅仅是试图在 字符串中找到模式。
目前还不完全清楚您的要求是什么 - 是“多于一个点在一起”还是“多于一个点在文本中的任意位置”?如果是后者,应该这样做:
if (myString.matches(".*\\..*\\..*")) {
...换句话说,任何东西,然后是一个点,然后是任何东西,然后是一个点,然后是任何东西——“任何东西”可以是“无”。所以这将匹配“He..llo”和“H.e.llo”,但不匹配“He.llo”。
希望这就是您想要的。如果你从字面上只是想要“它必须有..在某处”那么它更容易:
if (myString.contains(".."))
关于java - 一个字符串中有多少个点。 ( java ),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12082337/