3

我正在尝试编写一个正则表达式(用于 ASP.NET RegularExpressionValidator),以便:

如果要验证的字符串包含字母 A 后跟字母 B,则验证应该失败。

如果要验证的字符串包含字母 F 后跟 W、X、Y、Z 或任何数字,则验证应该失败。

我想出了这个

(AB)|(F(W|X|Y|Z|[0-9]))

但据我所知,如果输入与该表达式匹配,验证将成功。

如果输入与该表达式不匹配,我需要做什么才能使验证失败?

非常感谢,

大卫

4

4 回答 4

5

这就是负前瞻的用途

(?!.*AB)(?!.*F[WXYZ\d])

在这些字符串上失败。它还没有匹配任何文本(如果您只想检查是否有匹配项就足够了),因此匹配结果将始终为空字符串

于 2012-09-21T08:43:54.213 回答
3

这会起作用:

A[^B]|F[^WXYZ0-9]|[^AF].
  • A 后跟除 B 之外的任何内容,或
  • F 后跟除 W、X、Y、Z 或数字以外的任何内容,或
  • A 或 F 后跟任何单个字符的其他内容

请注意,这也将匹配“A$”或“@@”。如果你只想匹配“一个字母后跟一个字母或数字”,那么使用这个:

A[AC-Z0-9]|F[A-V]|[B-EG-Z][A-Z0-9]

正则表达式更擅长正匹配。

请注意,对于正则表达式验证器,整个字符串必须匹配(如果只有一个子字符串匹配,验证器会报告验证失败)

于 2012-09-21T08:31:16.517 回答
2

您可以使用您的编程语言提供的逻辑非运算符来否定匹配操作返回的结果,无需修改您的正则表达式。

编辑:如果以上不是一个选项,请查看这些问题123

于 2012-09-21T08:32:34.380 回答
1

您可以对此正则表达式进行匹配

^(?!^.*?AB)(?!^.*?F[WXYZ\d]).*$

是一个工作示例。基本上它的意思是“找到所有字符串,除了包含 AB 的字符串之前和之后具有任意数量的字符,以及包含 F 后跟 W、X、Y、Z 或数字的字符串”。Tim Pietzcker 的回答中提供了链接上的信息

于 2012-09-21T09:14:19.957 回答