例子: 这只是一个简单的句子。

我想匹配这句话和句子之间的每个字符。换行符应该被忽略。我想不出正确的语法。


当前回答

试试This is[\s\ s]*?句子,工作在javascript

其他回答

如果有人在Jenkins上下文中寻找这样的例子。它会解析build.log,如果找到匹配,就会失败。

import java.util.regex.Matcher;
import java.util.regex.Pattern;

node{    
    stage("parse"){
        def file = readFile 'build.log'

        def regex = ~"(?s)(firstStringToUse(.*)secondStringToUse)"
        Matcher match = regex.matcher(file)
        match.find() {
            capturedText = match.group(1)
            error(capturedText)
        }
    }
}

这样的:

This is (.*?) sentence

工作在javascript。

用这个:(?=开始名)(?=结束名)

例如

(?<=This is)(.*)(?=sentence)

Regexr

我使用了向后查找(?<=)和向前查找(?=),这样“This is”和“sentence”就不包含在匹配中,但这取决于你的用例,你也可以简单地写This is(.*)句子。

这里重要的是,您激活了正则表达式引擎的“dotall”模式,以便。匹配换行符。但是如何做到这一点取决于你的正则表达式引擎。

下一件事是如果你使用。*或。*?。第一个是贪婪的,将匹配到字符串中的最后一个“句子”,第二个是懒惰的,将匹配到字符串中的下一个“句子”。

更新

Regexr

This is(?s)(.*)sentence

(?s)打开dotall修饰符,使。匹配换行符。

更新2:

(?<=is \()(.*?)(?=\s*\))

匹配你的例子“这是(一个简单的)句子”。请看Regexr

需要惰性量词

重新提出这个问题是因为公认答案中的正则表达式对我来说似乎不太正确。为什么?因为

(?<=This is)(.*)(?=sentence)

会和我的第一句话相匹配。这是我的第一句话。这是我的第二句话。

看到演示。

在两个环视之间需要一个惰性量词。增加一个?使恒星变懒。

这是你想要的:

(?<=This is).*?(?=sentence)

看到演示。我删除了不需要的捕获组。

DOTALL模式匹配跨换行

注意,在演示中设置了“点匹配换行模式”(a.k.a)点-all(参见如何在各种语言中打开DOTALL)。在许多正则表达式中,您可以使用在线修饰符(?s)设置它,将表达式转换为:

(?s)(?<=This is).*?(?=sentence)

参考

正则表达式贪婪的多种程度 星号和加号重复