我正在尝试为字符串构造一个正则表达式,该字符串应具有以下条件:
- 它必须至少包含一个元音。
- 它不能包含三个连续的元音或三个连续的辅音。
- 它不能包含连续两次出现的同一字母,“ee”或“oo”除外。
我无法为第二个和第三个条件构建正则表达式。
例如: 凉亭 - 接受, 苹果 - 不接受, miiiixer - 不接受, 对冲 - 不接受, 喂养 - 接受
提前致谢!
编辑:
我的代码:
Pattern ptn = Pattern.compile("((.*[A-Za-z0-9]*)(.*[aeiou|AEIOU]+)(.*[@#$%]).*)(.*[^a]{3}.*)");
Matcher mtch = ptn.matcher("zoggax");
if (mtch.find()) {
return true;
}
else
return false;
最佳答案
以下内容应该适合您的需求:
(?=.*[aeiouy])(?!.*[aeiouy]{3})(?!.*[a-z&&[^aeiouy]]{3})(?!.*([a-z&&[^eo]])\\1).*
在 Java 中:
String regex = "(?=.*[aeiouy])(?!.*[aeiouy]{3})(?!.*[a-z&&[^aeiouy]]{3})(?!.*([a-z&&[^eo]])\\1).*";
System.out.println("bower".matches(regex));
System.out.println("appple".matches(regex));
System.out.println("miiixer".matches(regex));
System.out.println("hedding".matches(regex));
System.out.println("feeding".matches(regex));
打印:
true
false
false
false
true
说明:
(?=.*[aeiouy])
:包含至少一个元音(?!.*[aeiouy]{3})
:不包含 3 个连续的元音(?!.*[a-z&&[^aeiouy]]{3})
:不包含 3 个连续辅音[a-z&&[^aeiouy]]
:a
和z
之间的任意字母,但不包含aeiouy
(?!.*([a-z&&[^eo]])\1)
:不包含 2 个连续字母,e
和除外Ø
[a-z&&[^eo]]
:a
和z
之间的任何字母,但不是eo
参见http://www.regular-expressions.info/charclassintersect.html .
关于java - 如何在java中使用正则表达式否定元音条件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27778002/