gpt4 book ai didi

Java正则表达式判断是否至少有一个字母

转载 作者:行者123 更新时间:2023-11-29 04:26:09 25 4
gpt4 key购买 nike

我在 SO 和网络上发现了很多关于这个主题的变体,但大多数(如果不是全部)要求至少一个字母和一个数字。我需要至少一封信。我已经尝试过但我没有做对,我需要的是 String 只包含字母,字母 + 数字(任何顺序),允许使用破折号和空格,但不能在字符串的开头或结尾。这是它现在的样子:

protected static final String PATTERN = "[\u00C0-\u017Fa-zA-Z0-9']+([- ][\u00C0-\u017Fa-zA-Z0-9']+)*";

public static void main(String[] args) {

String name;

//name = "Street"; // allowed
//name = "Some-Street"; // allowed
//name = "Street "; // not allowed
//name = " Street"; // not allowed
//name = "Street-"; // not allowed
//name = "-Street"; // not allowed
//name = "Street"; // allowed
//name = "1 st street"; // allowed
//name = "street 5"; // allowed
name = "111"; // NOT allowed

if (!Pattern.matches(PATTERN, name)) {
System.out.println("ERROR!");
} else System.out.println("OK!");
}
}

如何添加检查是否至少有一个字符?

无论是在开头还是结尾,也不管它和数字之间是否有空格或破折号。必须至少有一个字符。

最佳答案

您可以使用此正则表达式来解决您的问题:

^(?=.*\pL)[\pL\pN]+(?:[ -]+[\pL\pN]+)*$

RegEx Demo

对于 Java 使用:

final String regex = "^(?=.*\\pL)[\\pL\\pN]+(?:[ -]+[\\pL\\pN]+)*$";

正则表达式分解:

  • ^:开始
  • (?=.*\pL):使用前瞻确保我们在某处至少有一个 unicode 字母
  • [\pL\pN]+:匹配一个或多个unicode字母或unicode数字
  • (?:: 非捕获组开始
    • [-]+:匹配一个或多个空格或连字符
    • [\pL\pN]+:匹配一个或多个unicode字母或unicode数字
  • )*:非捕获组结束。 * 表示该组中的零个或多个。
  • $:结束

关于Java正则表达式判断是否至少有一个字母,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46157300/

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