gpt4 book ai didi

java - 一个字符串中有多少个点。 ( java )

转载 作者:搜寻专家 更新时间:2023-11-01 01:00:51 25 4
gpt4 key购买 nike

所以,我正在开发一个程序,我需要在其中检查一个字符串是否有多个点。我去查看了 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com