如何在Scala中获得匹配的子组?

2024-06-28 10:56:38 发布

您现在位置:Python中文网/ 问答频道 /正文

我在python中有以下内容:

  regex.sub(lambda t: t.group(1).replace(" ", "  ") + t.group(2),string)    

其中regex是正则表达式,string是填充字符串。在

所以我尝试在Scala中做同样的事情,使用regex.replaceAllIn(...)函数而不是pythonsub。但是,我不知道如何得到匹配的子组。在

Scala中有没有类似于python函数group的东西?在


Tags: lambda函数字符串stringgroup事情replaceregex
3条回答

您可以使用replaceAll,并使用$n,其中“n”是要匹配的组。例如:

yourString.replaceAll(yourRegex, "$1")

用第一组替换匹配的零件。在

也许另一种方法是使用regex,例如:

val regExtractor = """a(b+)(c+)(d*)""".r

然后匹配String:

^{pr2}$

newString将是:

"String Replaced: XXXXX, YYYYY"

scaladoc有一个例子。提供来自Match的函数,而不是字符串。在

scala> val r = "a(b)(c)+".r
r: scala.util.matching.Regex = a(b)(c)+

scala> val s = "123 abcccc and abcc"
s: String = 123 abcccc and abcc

scala> r.replaceAllIn(s, m => s"a${m.group(1).toUpperCase}${m.group(2)*3}")
res0: String = 123 aBccc and aBccc

生成的字符串还执行组替换。在

^{pr2}$

相关问题 更多 >