显然,您可以使用|(管道?)来表示OR,但是是否也有一种方法来表示AND呢?

具体来说,我希望匹配包含某个短语的所有文本段落,但没有特定的顺序。


当前回答

看看这个例子:

我们有两个正则表达式A和B,我们想要匹配它们,所以在伪代码中它看起来像这样:

pattern = "/A AND B/"

它可以在不使用AND操作符的情况下写成这样:

pattern = "/NOT (NOT A OR NOT B)/"

PCRE:

"/(^(^A|^B))/"

regexp_match(pattern,data)

其他回答

如果你使用Perl正则表达式,你可以使用正向预测:

例如

(?=[1-9][0-9]{2})[0-9]*[05]\b

是否有大于100且能被5整除的数

AND运算符在RegExp语法中是隐式的。 相反,必须使用管道指定OR操作符。 下面的RegExp:

var re = /ab/;

意思是字母a和字母b。 它还适用于组:

var re = /(co)(de)/;

它的意思是基团co和基团de。 将(隐式的)AND替换为OR需要以下几行代码:

var re = /a|b/;
var re = /(co)|(de)/;

顺序总是隐含在正则表达式的结构中。为了实现您想要的结果,您必须针对不同的表达式多次匹配输入字符串。

您想要做的事情是无法通过单个regexp实现的。

下面是and运算符的可能“形式”:

以下面的正则表达式为例:

如果我们想匹配没有“e”字符的单词,我们可以这样做:

/\b[^\We]+\b/g

\W表示不是“单词”字符。 ^\W表示“字”字符。 [^\We]表示“单词”字符,而不是“e”。

看一下实际情况:没有e的单词

和“正则表达式的运算符”

我认为这个模式可以用作正则表达式的“和”操作符。

一般而言,如果:

A = not A B =非B

然后:

[^AB] = not(A or B) 
      = not(A) and not(B) 
      = a and b

差集

所以,如果我们想在正则表达式中实现差分集的概念,我们可以这样做:

a - b = a and not(b)
      = a and B
      = [^Ab]

看看这个例子:

我们有两个正则表达式A和B,我们想要匹配它们,所以在伪代码中它看起来像这样:

pattern = "/A AND B/"

它可以在不使用AND操作符的情况下写成这样:

pattern = "/NOT (NOT A OR NOT B)/"

PCRE:

"/(^(^A|^B))/"

regexp_match(pattern,data)