多次出现特定单词的正则表达式

Regex for multiple occurrences of specific words

你好

我正在尝试创建一个验证规则来检查正则表达式是否只接受特定的短语。正则表达式基于 Java.

以下是正确输入的示例:

  • 1OR2
  • 2
  • 1 OR 2 OR 15
  • ( 2OR3) AND 1
  • (12AND13 AND1)OR(4 AND5)
  • ((2AND3 AND 1)OR(4AND5))AND6
  • 但如果只有正则表达式可以接受类似的东西,我会很高兴:

    ())34AND(4

    我不知道如何创建一个正则表达式来检查括号是否正确打开和关闭(它们可以嵌套)。我假设不可能在正则表达式中检查它,所以对我已经在代码(堆栈实现)中制作的括号进行正确验证。在代码中,我对短语进行了第二步验证。

    我需要正则表达式做的就是检查短语中是否有这些特定的东西:

    允许使用数字、圆括号、多次出现的单词 AND 和 OR 以及空格。 它不应该接受字母或其他字符。 到目前为止我设法创建的是:

    ^[0-9 \(][0-9 \(\)]*

    还尝试添加如下内容:

    \b(AND|OR)\b

    在第二对括号内,但没有运气。

    我不知道如何更正它以添加 OR 和 AND 词。

    我使用了以下内容并匹配了您提供的所有输入:

    ^[^\)][0-9 \( (AND|OR)]*$
    

    我假设你不想以 ) 开头,这就是为什么我包含了 ^[^\)]。

    如果你不知道,我使用 https://www.regexpal.com 检查我的正则表达式代码。

    由于您有任意数量的嵌套元素,因此可以说使用正则表达式是不可能的。

    仅出于演示目的,这匹配零个或多个连词和一组括号:

    ^\d+(\s*(?:AND|OR)\s*(\d+|\(?\s*\d+(\s*(?:AND|OR)\s*\d+)\s*\)))*$|^(\d+|\(?\s*\d+(\s*(?:AND|OR)\s*\d+)\s*\))\s*(\s*(?:AND|OR)\s*\d+)*$
    

    就是这样。添加更多组和层级的嵌套括号会导致复杂性呈指数级增长 - 直到完全崩溃。

    Demo