繁体   English   中英

正则表达式电话号码模式

[英]regex telephone number pattern

我有3类电话号码,分别是Golden,Special和Normal。 我正在尝试做的是当用户键入电话号码时,它会自动确定属于哪个类别的电话号码。 让我举一个Golden类别编号的例子:AA001234(AA表示2位数,相同的数字如11,22,33等)。 这就是我得到的

public static void main(String[] args) {

    Scanner userinput = new Scanner(System.in);

    System.out.println("Enter Telephone Number");
    String nophone = userinput.next();

    String Golden = "(\\d{2})002345"; // <-- how to write the code if the user
    //enter the same digit for the first 2 number, it will belong to Golden category?
    String Special1 = "12345678|23456789|98765432|87654321|76543210";

    if (nophone.matches(Golden)) {
        System.out.println("Golden");
    }

    else if (nophone.matches(Special1)) {
        System.out.println("Special 1");
    }
    else {
        System.out.println("Normal");
    }
}

我不确定Java是否支持完整的正则表达式实现,但如果确实如此,您可以使用:

(\d)(\1)002345

\\1表示对第一个匹配(括号编辑)的反向引用,因此(\\d)(\\1)将连续匹配两个相同的数字。

如果Java不支持这个,我建议你硬编码,因为你只有3个类别。

你可以像(\\\\d)\\\\1那样使用反向引用。 (例如(\\\\d)\\\\1\\\\d* )。

哪里

  1. 第一个\\\\d表示一个数字
  2. \\\\1表示相同的数字和
  3. \\\\d*表示0位或更多位。

如果数字的长度不是一个问题,你可以使用它。 由于您使用的是Java,因此需要两个斜杠。
String Golden = "(\\\\d)\\\\1\\\\d*";

如果数字的长度恰好是8

String Golden = "(\\\\d)\\\\1\\\\d{6}";

如果你想匹配五个重复的数字,
String Golden = "(\\\\d)\\\\1{4}\\\\d*";

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM