Java正则表达式详解

1.1 正则表达式的概念以及演示

  • 正则表达式可以用一些规定的字符来制定规则,并用来校验数据格式的合法性。
  • 正则表达式就是用来验证各种字符串的规则。它内部描述了一些规则,我们可以验证用户输入的字符串是否匹配这个规则。正则表达式是一种强大的校验机制。
  • 在Java中,我们经常需要验证一些字符串,例如:年龄必须是2位的数字、用户名必须是8位长度而且只能包含大小写字母、数字等。

package com.gch.d7_regex;

public class RegexDemo1 {
    public static void main(String[] args) {
        // 需求:校验qq号码,必须全部数字6-20位且不能以0开头
        System.out.println(checkQQ("314314231432")); // true
        System.out.println(checkQQ("null")); // false
        System.out.println(checkQQ("2421")); // false
        System.out.println(checkQQ("1354315a543")); // false
        System.out.println("------------------------------");

        // 正则表达式的初体验
        System.out.println(checkQQ2("314314231432")); // true
        System.out.println(checkQQ2("null")); // false
        System.out.println(checkQQ2("2421")); // false
        System.out.println(checkQQ2("1354315a543")); // false

        String qq = "true";
        System.out.println((qq != null && qq.matches("[1-9]\\d{5,19}")));
    }
    public static boolean checkQQ2(String qq){ // \\d表示数字
        return qq != null && qq.matches("[1-9]\\d{5,19}");
    }
    public static boolean checkQQ(String qq){
        // 核心思想:
        // 先把异常数据进行过滤
        // 下面的就是满足要求的数据了
        // 1.判断qq号码的长度是否满足要求
        if(qq == null || qq.length() < 6 || qq.length() > 20 || qq.startsWith("0")){
            return false;
        }

        // 2.判断qq中是否全部是数字,不是返回false
        for(int i = 0;i < qq.length();i++){
            // 获取每位字符
            char ch = qq.charAt(i);
            // 判断这个字符是不是数字,不是数字直接返回false
            // 说明还没到数字区域
            if(ch < '0' || ch > '9'){
                return false;
            }
        }
        return true; // 肯定合法了
    }
}

1.2 正则表达式的使用详解

 

 

package com.gch.d7_regex;

public class RegexDemo2 {
    public static void main(String[] args) {
        //public boolean matches(String regex):判断是否与正则表达式匹配,匹配返回true
        // 正则表达式的一些常见匹配规则
        // 只能是a b c  一个[]表示一个字符
        System.out.println("-----------1-------------");
        System.out.println("a".matches("[abc]")); // true
        System.out.println("z".matches("[abc]")); // false
        // 一个[]表示一个字符,第二个b没有什么东西跟它去匹配,所以不满足为false
        System.out.println("ab".matches("[abc]")); // false
        System.out.println("ab".matches("[abc][abc]")); // true

        // 不能出现a b c , ^表示取反的意思
        System.out.println("-----------2-------------");
        System.out.println("a".matches("[^abc]")); // false
        System.out.println("z".matches("[^abc]")); // true
        System.out.println("zz".matches("[^abc]")); //false
        System.out.println("zz".matches("[^abc][^abc]")); //true

        // a到zA到Z(包括头尾的范围) , -写在[]里面表示范围的意思,写在[]外面表示就是一个-
        System.out.println("-----------3-------------");
        System.out.println("a".matches("[a-zA-Z]")); // true
        System.out.println("z".matches("[a-zA-Z]")); // true
        System.out.println("aa".matches("[a-zA-Z]"));//false
        System.out.println("zz".matches("[a-zA-Z]")); //false
        // 第一个z跟第一个[]去匹配  第二个z跟第二个[]去匹配
        System.out.println("zz".matches("[a-zA-Z][a-zA-Z]")); //true
        System.out.println("0".matches("[a-zA-Z]"));//false
        System.out.println("0".matches("[a-zA-Z0-9]"));//true
        System.out.println("0".matches("[0-9]"));//true


        // [a-d[m-p]] a到d,或m到p
        System.out.println("-----------4-------------");
        System.out.println("a".matches("[a-d[m-p]]"));//true
        System.out.println("d".matches("[a-d[m-p]]")); //true
        System.out.println("m".matches("[a-d[m-p]]")); //true
        System.out.println("p".matches("[a-d[m-p]]")); //true
        System.out.println("e".matches("[a-d[m-p]]")); //false
        System.out.println("0".matches("[a-d[m-p]]")); //false

        // [a-z&&[def]] a-z和def的交集。为:d,e,f
        // 细节:如果要求两个范围的交集,那么需要写符号&&
        // 如果写成了一个&,那么此时&表示就不是交集了,而是一个简简单单的&符号,没有任何含义
        System.out.println("----------5------------");
        System.out.println("a".matches("[a-z&[def]]")); //true
        System.out.println("&".matches("[a-z&[def]]")); //true

        System.out.println("a".matches("[a-z&&[def]]")); //false
        System.out.println("&".matches("[a-z&&[def]]")); //false
        System.out.println("d".matches("[a-z&&[def]]")); //true
        System.out.println("0".matches("[a-z&&[def]]")); //false

        // [a-z&&[^bc]] a-z之间排除了b,c  a-z和非bc的交集。(等同于[ad-z])
        System.out.println("-----------6------------_");
        System.out.println("a".matches("[a-z&&[^bc]]"));//true
        System.out.println("b".matches("[a-z&&[^bc]]")); //false
        System.out.println("0".matches("[a-z&&[^bc]]")); //false

        // [a-z&&[^m-p]] a到z和除了m到p的交集。(等同于[a-lq-z])
        System.out.println("-----------7-------------");
        System.out.println("a".matches("[a-z&&[^m-p]]")); //true
        System.out.println("m".matches("[a-z&&[^m-p]]")); //false
        System.out.println("0".matches("[a-z&&[^m-p]]")); //false
    }
}
package com.gch.d7_regex;

public class RegexDemo3 {
    public static void main(String[] args) {
        // 正则表达式的一些常见匹配规则
        // \ 转义字符 改变后面那个字符原本的含义
        //练习:以字符串的形式打印一个双引号
        //双引号"在Java中表示字符串的开头或者结尾
        //此时\表示转义字符,改变了后面那个双引号原本的含义
        //把他变成了一个普普通通的双引号而已。
        System.out.println("\""); // "

        // \表示转义字符
        //         这个\转义了后面的U  这个/转义了后面的m
//        System.out.println("c:\Users\moon\IdeaProjects\\basic-code\\myapi\\src");
        //两个\的理解方式:前面的\是一个转义字符,改变了后面\原本的含义,把他变成一个普普通通的\而已。
        System.out.println("c:Users\\moon\\IdeaProjects\\basic-code\\myapi\\src\\com\\itheima\\a08regexdemo\\RegexDemo1.java");


        //.表示任意一个字符  一个.只能表示一个字符
        // 两个.表示前面需要有两个任意的字符
        System.out.println("----------------1-----------------");
        System.out.println("你".matches("..")); //false
        System.out.println("你".matches(".")); //true
        System.out.println("你a".matches(".."));//true

        // \\d 表示任意的一个数字
        // \\d只能是任意的一位数字
        // 简单来记:在Java当中两个\表示一个\,因为一个\有特殊含义,表示转义字符
        System.out.println("-----------------2----------------");
        System.out.println("a".matches("\\d")); // false
        System.out.println("3".matches("\\d")); // true
        System.out.println("333".matches("\\d")); // false
        System.out.println("333".matches("\\d\\d\\d")); // true

        //\\w,小写w 只能是一位单词字符[a-zA-Z_0-9] 可以是字母、数字或者下划线
        System.out.println("-----------------3----------------");
        System.out.println("z".matches("\\w")); // true
        System.out.println("2".matches("\\w")); // true
        System.out.println("21".matches("\\w")); // false
        System.out.println("你".matches("\\w"));//false
        System.out.println("_".matches("\\w"));//true

        // 非单词字符 大写W
        System.out.println("----------------4---------------");
        System.out.println("你".matches("\\W")); // true
        // 以上正则匹配/表达式只能校验单个字符。
        
        // 必须是数字 字母 下划线 至少 6位
        System.out.println("-------------5---------------");
        System.out.println("123213".matches("\\w{6,}"));
        System.out.println("2442fsfsf".matches("\\w{6,}"));//true
        System.out.println("244f".matches("\\w{6,}"));//false

        // 必须是数字和字符 必须是4位
        System.out.println("------------6-----------------");
        System.out.println("shai".matches("[0-9a-zA-Z]{4}"));//true
        System.out.println("23dF".matches("[a-zA-Z0-9]{4}"));//true
        System.out.println("23 F".matches("[a-zA-Z0-9]{4}"));//false
        System.out.println("adbc".matches("[\\w&&[^_]]{4}"));//true
        System.out.println("23dF".matches("[\\w&&[^_]]{4}"));//true
        System.out.println("23_F".matches("[\\w&&[^_]]{4}"));//false
    }
}

1.3 正则表达式的常见案例

package com.gch.d7_regex;

public class RegexDemo4 {
    public static void main(String[] args) {
        /*
            需求
            请编写正则表达式验证用户输入的手机号码是否满足要求。请编写正则表达式验证用户输入的邮箱号是否满足要求。请编写正则表达式验证用户输入的电话号码是否满足要求。
            验证手机号码 13112345678 13712345667 13945679027 139456790271
            验证座机电话号码 020-2324242 02122442 027-42424 0712-3242434
            验证邮箱号码 3232323@qq.com zhangsan@itcast.cnn dlei0009@163.com dlei0009@pci.com.cn
        */

        //心得:
        //拿着一个正确的数据,从左到右依次去写,一个一个的去看
        //13112345678
        //分成三部分:
        //第一部分:1 表示手机号码只能以1开头
        //第二部分:[3-9] 表示手机号码第二位只能是3-9之间的
        //第三部分:\\d{9} 表示任意数字可以出现9次,也只能出现9次
        System.out.println("----------------1------------------");
        String regex1 = "1[3-9]\\d{9}";
        System.out.println("13112345678".matches(regex1));//true
        System.out.println("13712345667".matches(regex1));//true
        System.out.println("13945679027".matches(regex1));//true
        System.out.println("139456790271".matches(regex1));//false

        //座机电话号码
        //020-2324242 02122442 027-42424 0712-3242434
        //思路:
        //在书写座机号正则的时候需要把正确的数据分为三部分
        //一:区号0\\d{2,3}
        //      0:表示区号一定是以0开头的
        //      \\d{2,3}:表示区号从第二位开始可以是任意的数字,可以出现2到3次。
        //二:- ?表示次数,0次或一次
        //三:号码 号码的第一位也不能以0开头,从第二位开始可以是任意的数字,号码的总长度:5-10位
        System.out.println("------------------2--------------------");
        String regex2 = "0\\d{2,3}-?[1-9]\\d{4,9}";
        System.out.println("020-2324242".matches(regex2)); // true
        System.out.println("02122442".matches(regex2)); // true
        System.out.println("027-42424".matches(regex2)); // true
        System.out.println("0712-3242434".matches(regex2)); // true

        //邮箱号码
        //3232323@qq.com   zhang_san@itcast.cnn    dlei0009@163.com     dlei0009@pci.com.cn
        //思路:
        //在书写邮箱号码正则的时候需要把正确的数据分为三部分
        //第一部分:@的左边 \\w+  +表示一次或者多次,即至少出现一次
        //        \\w:a-z A-Z 0-9 _
        //        表示任意的字母数字下划线,至少出现一次就可以了
        //第二部分:@ 表示只能出现一次,也只能出现一次
        //第三部分:
        //                   [\\w&&[^_]]:表示任意的字符去掉下划线
        //      3.1         .的左边[\\w&&[^_]]{2,6}
        //                  任意的字母加数字,总共出现2-6次(此时不能出现下划线)
        //      3.2         . \\. 在Java当中两个\表示一个\
        //      3.3         大写字母,小写字母都可以,只能出现2-3次[a-zA-Z]{2,3}
        //      我们可以把3.2和3.3看成一组,这一组可以出现1次或者两次
        System.out.println("----------------3------------------");
        String regex3 = "\\w+@[\\w&&[^_]]{2,6}(\\.[a-zA-Z]{2,3}){1,2}";
        System.out.println("3232323@qq.com".matches(regex3)); // true
        System.out.println("zhangsan@itcast.cnn".matches(regex3)); // true
        System.out.println("dlei0009@163.com".matches(regex3)); // true
        System.out.println("dlei0009@pci.com.cn".matches(regex3)); // true


        // 在实际开发中,很少会自己写正则表达式
        // 百度一个类似的,自己改成公司要求的
        String regex = "";
        System.out.println("-----------------4----------------");
        //24小时的正则表达式
        String regex4 = "([01]\\d|2[0-3]):[0-5]\\d:[0-5]\\d";
        System.out.println("23:11:11".matches(regex4));

        String regex5 = "([01]\\d 2[0-3])(:[0-5]\\d){2}";
        System.out.println("23:11:11".matches(regex5));
    }
}

1.4 正则表达式在方法中的应用

package com.gch.d7_regex;

import java.util.Arrays;

/**
   目标:正则表达式在方法中的使用
     public String[] split(String regex):
         -- 按照正则表达式匹配的内容进行分割字符串,返回一个字符串数组
     public String replaceAll(String regex,String newStr)
         -- 按照正则表达式匹配的内容进行替换
 */
public class RegexDemo6 {
    public static void main(String[] args) {
        String names = "小路dsahid123蓉儿3242asfda过儿";

        String[] arrs = names.split("\\w+");
        System.out.println(Arrays.toString(arrs));
        for (int i = 0; i < arrs.length; i++) {
            System.out.println(arrs[i]);
        }

        String names2 = names.replaceAll("\\w+" ," ");
        System.out.println(names2);
    }
}

 

 

 1.5 正则表达式爬取信息

package com.gch.d7_regex;

import java.util.regex.Matcher;
import java.util.regex.Pattern;

/**
 拓展:正则表达式爬取信息中的内容。(了解)
 */
        public class RegexDemo7 {
            public static void main(String[] args) {
                String rs = "来黑马程序学习Java,电话020-43422424,或者联系邮箱" +
                        "itcast@itcast.cn,电话18762832633,0203232323" +
                        "邮箱bozai@itcast.cn,400-100-3233 ,4001003232";

                // 需求:从上面的内容中爬取出 电话号码和邮箱。
                // 1、定义爬取规则,字符串形式
                String regex = "(\\w{1,30}@[a-zA-Z0-9]{2,20}(\\.[a-zA-Z0-9]{2,20}){1,2})|(1[3-9]\\d{9})" +
                        "|(0\\d{2,6}-?\\d{5,20})|(400-?\\d{3,9}-?\\d{3,9})";

                // 2、把这个爬取规则编译成匹配对象。
                Pattern pattern = Pattern.compile(regex);

                // 3、得到一个内容匹配器对象
                Matcher matcher = pattern.matcher(rs);

                // 4、开始找了
                while (matcher.find()) {
                    String rs1 = matcher.group();
                    System.out.println(rs1);
                }
            }
        }

 

 

文章出处登录后可见!

已经登录?立即刷新

共计人评分,平均

到目前为止还没有投票!成为第一位评论此文章。

(0)
心中带点小风骚的头像心中带点小风骚普通用户
上一篇 2023年12月6日
下一篇 2023年12月6日

相关推荐

此站出售,如需请站内私信或者邮箱!