他们需要一个Java中的正则表达式,如果字符串文字是任何而不是3个字母的单词NIL,则返回true。测试需要不区分大小写,RegEx本身必须完成所有工作。
因此,RegEx应拒绝 NIL,nil,NiL,nIL,等。
然而,它应该接受:nile,anil,will,zappa-nil-a和空字符串。编写一个简单的RegEx需要多少Java开发人员?显然很多!
答案 0 :(得分:18)
您可以使用negative lookahead。
执行此操作启用不区分大小写的选项:
^(?!nil$).*
如果你不需要在匹配中真正返回字符串,你可以在最后留下.*
。这是一个没有不区分大小写的选项的版本:
^(?![nN][iI][lL]$).*
说明:
^ # start of string anchor
(?! # start negative lookahead (fail if...)
nil # literal characters 'nil'
$ # end of string
) # end lookahead
.* # consume string (not necessary, but it acts more like a typical regex)
如果您希望正则表达式与nil\n
匹配,请在前瞻中使用\z
代替$
:^(?!nil\z).*
答案 1 :(得分:5)
这是一个真正的正则表达式,直接指定一个有限的自动机,可以逐个输入字符串的字符,如果字符串不是NIL的变体,将达到接受状态:
(|.|..|[^Nn]..|.[^Ii].|..[^Ll]|....+)
这适用于没有实现环视黑客攻击的经典正则表达式引擎,可以转换为超快的DFA。
您可能必须使用^
和$
来锚定它,具体取决于您使用的正则函数类型:(整个字符串)匹配语义或子字符串搜索语义。
例如,grep test:
# rejects lines like nIl and NiL but accepts all else
# including blank lines:
grep -E '^(|.|..|[^Nn]..|.[^Ii].|..[^Ll]|....+)$'
这里的想法是:
如何拒绝NIL和Nil是因为它们都失败了所有三个规则2.1,2.2和2.3。 NIL确实以N开头,因此它失败了2.1。它确实有一个I在中间,所以它失败了2.2,它最后有一个L,所以它失败了2.3。