gpt4 book ai didi

java - 如何在java中使用正则表达式否定元音条件

转载 作者:行者123 更新时间:2023-11-30 03:36:31 24 4
gpt4 key购买 nike

我正在尝试为字符串构造一个正则表达式,该字符串应具有以下条件:

  1. 它必须至少包含一个元音。
  2. 它不能包含三个连续的元音或三个连续的辅音。
  3. 它不能包含连续两次出现的同一字母,“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]]:az 之间的任意字母,但不包含 aeiouy
  • (?!.*([a-z&&[^eo]])\1):不包含 2 个连续字母,e 除外Ø
    • [a-z&&[^eo]]:az 之间的任何字母,但不是 eo

参见http://www.regular-expressions.info/charclassintersect.html .

关于java - 如何在java中使用正则表达式否定元音条件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27778002/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com