Java:如何从正则表达式解析双精度

我有一个看起来像“ A = 1.23; B = 2.345; C = 3.567”的字符串

我只对“ C = 3.567”感兴趣

到目前为止,我有:

     Matcher m = Pattern.compile("C=\\d+.\\d+").matcher("A=1.23;B=2.345;C=3.567");

while(m.find()){

double d = Double.parseDouble(m.group());

System.out.println(d);

}

问题是它显示3与567分开

输出:

3.0

567.0

我想知道如何包含小数点,以便输出“ 3.567”

编辑:如果没有小数点,我也想匹配C:所以我想捕获3567和3.567

由于C =也是内置在模式中的,因此在解析double之前如何去除它?

回答:

我可能会在这部分上弄错了,但之所以将两者分开是因为

group()仅匹配最后匹配的子序列,这是每次find()调用都会匹配的东西。

谢谢马克·拜尔斯。

但是可以肯定的是,您可以通过将所需的整个零件放在“捕获组”中来解决此问题,这可以通过将其放在括号中来完成。这样一来,您就可以将正则表达式的匹配部分组合到一个子字符串中。您的模式将如下所示:

Pattern.compile("C=(\\d+\\.\\d+)")

对于解析3567或3.567,您的模式将是C=(\\d+(\\.\\d+)?)第1组代表整数。

另外,请注意,由于您特别想匹配一个句点,因此您希望转义.(句点)字符,以便不将其解释为“任何字符”标记。不过,对于此输入,这并不重要

然后,要得到3.567,您将呼叫m。group(1)获取第一个(从1开始计数)指定的组。这意味着您的Double.parseDouble调用实际上将变为Double.parseDouble("3.567")

至于将C =从您的模式中删除,由于我对RegExp不太了解,因此我建议您在分号上分割输入字符串,然后检查每个分割是否包含C。那么您可以应用模式(与捕获组一起使用)从Matcher中获取3.567。

编辑 对于gawi评论中更一般(可能更有用!)的案例,请使用以下内容(来自http://www.regular-

expressions.info/floatingpoint.html)

Pattern.compile("[-+]?[0-9]*\\.?[0-9]+([eE][-+]?[0-9]+)?")

它支持可选符号,可选整数或可选小数部分以及可选正/负指数。在需要的地方插入捕获组以单独挑选零件。整个指数都在自己的组中,以使其整体上是可选的。

以上是 Java:如何从正则表达式解析双精度 的全部内容, 来源链接: utcz.com/qa/406675.html

回到顶部