1

我被一个正则表达式问题难住了。我一直在将它们用于一个项目并且它们一直在完美地工作,但后来我遇到了一种情况,我认为可以通过积极的前瞻性来解决,但我的尝试并没有达到我的预期。

为了说明,我在下面画了一条线。其中,我想返回两个匹配项,第一个包含“This”和“thisThing”,另一个包含“That”和“thatThing”,其中第一个值只能是“This”或“That” " 并且第二个值可以是任何 (\w*) 模式。

adsf(49) asd k:38* K.This(jfkael dk&$% thisThing) and K.That($$$$ djaf aj_dfj^^ ^ thatThing);

我认为这将是这样的:

K\.(This|That)  (????????????????)    (\w*)(?=\))

意思是,找到出现在“K”之后的“This”或“That”。然后得到“)”之前的第一个单词。但是,我真的不明白我如何指定(向前看,直到找到“)”,然后回溯,直到你得到它背后的单词。这样的事情可能吗?

4

2 回答 2

3

您可以使用非贪婪量词

K\.(This|That).*?(\w*)\)

或:(如果您不希望右括号成为匹配的一部分)

K\.(This|That).*?(\w*)(?=\))

这样,它将匹配 This|That 和单词之间的任何内容,但它是懒惰的(所以一旦找到一个好的匹配项,\w*它就会使用它,如果没有)跟随者则回溯)

于 2012-06-13T19:58:10.510 回答
2

怎么样:K\.(This|That)\(.*?(\w+)\)

这非贪婪地匹配括号之间的部分,但只要在右括号之前只剩下单词字符就停止。

于 2012-06-13T19:59:34.470 回答