我需要检查是否有一串很多单词/字母/等,只包含一组三重双引号(即“”“),但也可以包含单引号(”)和双引号( “”),使用正则表达式。到目前为止还没有取得多大成功。
具有负向前瞻的正则表达式可以做到:
(?!.*"{3}.*"{3}).*"{3}.*
我试过这些java代码:
String good = "hello \"\"\" hello \"\" hello ";
String bad = "hello \"\"\" hello \"\"\" hello ";
String regex = "(?!.*\"{3}.*\"{3}).*\"{3}.*";
System.out.println( good.matches( regex ) );
System.out.println( bad.matches( regex ) );
...输出:
true
false
尝试使用出现次数运算符来精确匹配三个双引号。
我很快用http://www.regextester.com/检查,似乎工作正常。
但是,如何以您选择的语言正确编译正则表达式可能会有所不同!
取决于您的语言,但您只需要匹配三个双引号(例如,/\"{3}/
),然后计算匹配项以查看是否只有一个。
可能有很多方法可以做到这一点,但一个简单的方法是只查找多次出现的三引号然后反转正则表达式。以下是Perl的一个例子:
use strict;
use warnings;
my $match = 'hello """ hello "" hello';
my $no_match = 'hello """ hello """ hello';
my $regex = '[\"]{3}.*?[\"]{3}';
if ($match !~ /$regex/) {
print "Matched as it should!\n";
}
if ($no_match !~ /$regex/) {
print "You shouldn't see this!\n";
}
哪个输出:
Matched as it should!
基本上,你告诉它找到你不想要的东西,然后反转真相。希望有道理。如果您需要帮助,可以帮助您将示例转换为另一种语言。
这对你来说可能是一个好的开始。
^(\"([^\"\n\\]|\\[abfnrtv?\"'\\0-7]|\\x[0-9a-fA-F])*\"|'([^'\n\\]|\\[abfnrtv?\"'\\0-7]|\\x[0-9a-fA-F])*'|\"\"\"((?!\"\"\")[^\\]|\\[abfnrtv?\"'\\0-7]|\\x[0-9a-fA-F])*\"\"\")$
在regex101.com看到它的行动。