我正在工作的电子邮件验证,将允许添加电子邮件地址,只要他们不是来自某些TLD。问题是,我的正则表达式并没有像我期望的那样运行。我希望它确保电子邮件是有效的,并且没有一些TLD,例如,我想要'johndoe@domain.com‘,但我不想要'johndoe@domain.xyz’,而在第二个示例中,我正在阻止添加'xyz‘电子邮件的TLD。这是我目前的正则表达式:
^[a-zA-Z0-9]+[a-zA-Z0-9._%-]*@.*\.(?!xyz)$
问题是,TLD会去哪里,它根本不会匹配任何东西。它不会与xyz匹配,但它也不会与org、com、net或任何其他TLD匹配。当涉及到正则表达式时,我并不是太高级,但我认为负Lookahead只会阻塞它后面的字符串,而不会阻塞它后面的任何东西。
任何帮助都是非常感谢的。
发布于 2019-03-20 04:24:38
通过使用负向先行,您告诉正则表达式不匹配xyz (?!xyz)
,但是您没有告诉它要匹配什么。
如果您想匹配其他内容,只需在(?!xyz)
后面附加.*
即可
^[a-zA-Z0-9]+[a-zA-Z0-9._%-]*@.*\.(?!xyz).*$
https://stackoverflow.com/questions/55249380
复制相似问题