Java SE 学习笔记(十)—— 正则表达式

news2024/12/24 22:00:55

目录

  • 1 引言
  • 2 常用匹配规则
    • 2.1 字符类
    • 2.2 预定义的字符类
    • 2.3 贪婪的量词
  • 3 正则表达式匹配的 API
  • 4 正则表达式应用
    • 4.1 正则表达式常见应用案例
    • 4.2 正则表达式在字符串方法中的使用
    • 4.3 正则表达式爬取信息

1 引言


😍 正则表达式可以用一些规定的字符来制定规则,并用来校验数据格式的合法性。

在这里插入图片描述

2 常用匹配规则


2.1 字符类


默认匹配一个字符

[abc] :只能是a 、b、或者 c

[^abc]: 除了a 、b、 c 之外的任意字符

[a-zA-Z]: a 到 z A 到 Z(范围)

[a-d[m-p]] :a 到 d 或者 m 到 p(并集)

[a-z&&[def]]: d、e 或 f (交集)

[a-z&&[^bc]]: a 到 z,除了 b、c

[a-z&&[^m-p]] : a 到 z,除了 m 到 p

2.2 预定义的字符类


默认匹配一个字符

.:任意字符

\d:一个数字:[0-9]

\D:非数字:[^0-9]

\s:一个空白字符:[\t\n\x0B\f\r]

\S:非空白字符:[^\s]

\w:英文、数字、下划线: [a-zA-Z_0-9]

\W:非英文、数字、下划线: [^\w]

2.3 贪婪的量词


配合匹配多个字符

?:前面的字符出现 0 次或 1 次

*:前面的字符出现 0 次或 多 次

+:前面的字符出现 1 次或 多 次

{n}:前面的字符出现 n 次

{n,}:前面的字符至少出现 n 次

{n,m}:前面的字符至少出现 n 次,但不超过 m 次

3 正则表达式匹配的 API


字符串对象提供了匹配正则表达式规则的 API

public boolean matches(String regex)

判断指定字符串是否匹配正则表达式,匹配返回true、不匹配返回false

🙋举个栗子:

public class Demo {
    public static void main(String[] args) {
        // 只能出现a、b、c
        System.out.println("a".matches("[abc]")); // true
        // 默认只匹配一个字符
        System.out.println("ab".matches("[abc]")); // false
        System.out.println("ab".matches("[abc]+")); // true

        // 不能出现a、b、c
        System.out.println("a".matches("[^abc]")); // false
        System.out.println("z".matches("[^abc]")); // true

        // 匹配数字
        System.out.println("3".matches("\\d")); // true
        System.out.println("a".matches("\\d")); // false

        // 匹配数字、字母、_
        System.out.println("_".matches("\\w")); // true
        System.out.println("24".matches("\\w")); // false
        System.out.println("我".matches("\\w")); // false
        System.out.println("我".matches("\\W")); // true

        System.out.println("-------------------------");

        // 校验密码:必须是数字、字母、下划线,至少6位
        System.out.println("2ugyftyf2".matches("\\w{6,}")); // true

        // 验证码,必须是数字、字符,必须是4位
        System.out.println("34jh".matches("[a-zA-Z0-9]{4}")); // true
        System.out.println("34jh".matches("[\\w&&[^_]]{4}")); // true
    }
}

4 正则表达式应用

4.1 正则表达式常见应用案例


😎 需求

  • 请编写程序模拟用户输入手机号码、验证格式正确,并给出提示,直到格式输入正确为止。
  • 请编写程序模拟用户输入邮箱号码、验证格式正确,并给出提示,直到格式输入正确为止。
  • 请编写程序模拟用户输入电话号码、验证格式正确,并给出提示,直到格式输入正确为止。

😵 分析

  • 定义方法,接收用户输入的数据,使用正则表达式完成检验,并给出提示。

😇 示例代码:

import java.util.Scanner;

public class Demo {
    public static void main(String[] args) {
        checkPhone();
        checkEmail();
        checkTel();
    }
    public static void checkPhone(){
        Scanner sc =new Scanner(System.in);
        while (true) {
            System.out.println("请您输入你的注册手机号码:");
            String phone = sc.next();
            if (phone.matches("1[3-9]\\d{9}")){
                System.out.println("手机号码格式正确,注册成功!");
                break;
            }else{
                System.out.println("手机号码格式有误!");
            }
        }
    }
    public static void checkEmail(){
        Scanner sc =new Scanner(System.in);
        while (true) {
            System.out.println("请您输入你的邮箱:");
            String phone = sc.next();
            // 123@qq.com
            // 23ggyfgy@163.com
            // 331122weiwei@pci.com.cn
            // 这里注意.的正则表达式
            if (phone.matches("\\w{1,30}@[a-zA-Z0-9]{2,20}(\\.[a-zA-Z0-9]){1,2}")){
                System.out.println("邮箱格式正确,注册成功!");
                break;
            }else{
                System.out.println("邮箱格式有误!");
            }
        }
    }
    public static void checkTel(){
        Scanner sc =new Scanner(System.in);
        while (true) {
            System.out.println("请您输入你的电话号码:");
            String phone = sc.next();
            if (phone.matches("0\\d{2,6}-?\\d{5,20}")){
                System.out.println("电话号码格式正确,注册成功!");
                break;
            }else{
                System.out.println("电话号码格式有误!");
            }
        }
    }
}

4.2 正则表达式在字符串方法中的使用


在这里插入图片描述
🙋举个栗子:

public class Demo {
    public static void main(String[] args) {
        String names = "张三huuigh7566756李四vtftr65675王五tftyftyfty999赵六";
        String[] arrs = names.split("\\w+");
        for (int i = 0; i < arrs.length; i++) {
            System.out.println(arrs[i]);
        }
        /*
        /张三
        李四
        王五
        赵六
         */
        String s = names.replaceAll("\\w+", "\\\\");
        System.out.println(s); // 张三\李四\王五\赵六
        
        String s1 = names.replaceAll("\\w+", "\t");
        System.out.println(s1); // 张三	李四	王五	赵六

        String s2 = names.replaceAll("\\w+", "\\t"); // 同直接替换成t
        System.out.println(s2); // 张三t李四t王五t赵六
    }
}

4.3 正则表达式爬取信息


正则表达式支持爬取指定的信息

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

public class Demo {
    public static void main(String[] args) {
        String rs = "来学习Java,电话020-43422424,或者联系邮箱" +
                "ibeit@ibeit.cn,电话18762832533,0203232323" +
                "邮箱bozai@itcast.cn,400-150-3233 ,4001073232";
        // 需求:从上面的内容中爬取出 电话号码和邮箱
        // 1.定义爬取规则
        String regex = "(\\w{1,}@\\w{2,10}(\\.\\w{2,10}){1,2})|" +
                "(1[3-9]\\d{9})|(0\\d{2,5}-?\\d{5,15})|400-?\\d{3,8}-?\\d{3,8}";
        // 2.编译正则表达式成为一个匹配规则对象
        Pattern pattern = Pattern.compile(regex);
        // 3.通过匹配规则对象得到一个匹配数据内容的匹配器对象
        Matcher matcher = pattern.matcher(rs);
        // 4.通过匹配器去内容中爬取出信息
        while (matcher.find()) {
            System.out.println(matcher.group());
        }
        /*
        020-43422424
        ibeit@ibeit.cn
        18762832533
        0203232323
        bozai@itcast.cn
        400-150-3233
        4001073232
        * */
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/877126.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

四步搭建自己的专属 ChatGPT(附开源代码)

在未来&#xff0c;ChatGPT将成为人工智能应用领域的支柱&#xff0c;推动人机交互、智能客服和在线教育等领域的发展。使用ChatGPT能够轻松应对各种语言任务&#xff0c;提高工作效率&#xff0c;带来更多的便利和创新。 软件架构 java后台技术采用renren框架&#xff1a;spr…

encoder-decoder

transformer的encoder-decoder 如果考虑一个由 2 个堆叠编码器和解码器组成的 Transformer&#xff0c;看起来会是这样的&#xff1a; 文章写的非常好&#xff1a;http://jalammar.github.io/illustrated-transformer/ 其中解码器中的自关注层的运行方式与编码器中的运行方式略…

考研数据结构:第七章 查找

文章目录 一、查找的基本概念二、顺序查找和折半查找2.1顺序查找2.3折半查找2.3.1算法思想2.3.2代码实现2.3.3查找效率分析2.3.4折半查找判定树的构造2.3.5折半查找效率2.3.6小结 2.4分块查找 三、树形查找3.1二叉排序树3.1.1二叉排序树定义3.1.2查找操作3.1.3插入操作3.1.4二叉…

arm:day2

.text 文本段 .global _start 声明一个_start全局函数的入口 _start: _start标签&#xff0c;就是c语言的函数/*mov r0,#9 r09mov r1,#15 r115cmp r0,r1 比较r0和r1beq stop 如果r0等于r1&#xff0c;跳转stopsubhi r0,r0,r1 如果r0大于r1&#xff0c;r0r0-r1su…

leetcode剑指 Offer 05. 替换空格(两种方法)

题目&#xff1a;leetcode剑指 Offer 05. 替换空格 描述&#xff1a; 请实现一个函数&#xff0c;把字符串 s 中的每个空格替换成"%20"。 示例 1&#xff1a; 输入&#xff1a;s “We are happy.” 输出&#xff1a;“We%20are%20happy.” 思路&#xff1a; 第一…

Python爬虫:单线程、多线程、多进程

前言 在使用爬虫爬取数据的时候&#xff0c;当需要爬取的数据量比较大&#xff0c;且急需很快获取到数据的时候&#xff0c;可以考虑将单线程的爬虫写成多线程的爬虫。下面来学习一些它的基础知识和代码编写方法。 一、进程和线程 进程可以理解为是正在运行的程序的实例。进…

MySQL索引总结

MySQL索引总结 1.索引的概念、作用与使用场景 本质上就是减少读写磁盘的次数。 索引是一种特殊的文件&#xff0c;包含这对数据表中所有记录的引用指针&#xff0c;可以对表中的一列或多列创建索引&#xff0c;并指定索引的类型&#xff0c;每种类型都有对应数据结构实现。 …

大数据必回之LSM树

LSM树&#xff08;Log-Structured-Merge-Tree&#xff09;并不像B、红黑树一样是一颗严格的树状数据结构&#xff0c;它其实是一种存储结构&#xff0c;像HBase、RocksDB这些NoSQL存储都是采用LSM树。它是一种分层、有序、面向磁盘的数据结构&#xff0c;核心思想是顺序写性能远…

Leetcode链表篇 Day3

.24. 两两交换链表中的节点 - 力扣&#xff08;LeetCode&#xff09; 1.构建虚拟结点 2.两两一组&#xff0c;前继结点一定在两两的前面 3.保存结点1和结点3 19. 删除链表的倒数第 N 个结点 - 力扣&#xff08;LeetCode&#xff09; 1.双指针&#xff1a;快慢指针 两个指针的差…

初步认识OSI/TCP/IP一(第三十八课)

1 初始OSI模型 OSI参考模型&#xff08;Open Systems Interconnection Reference Model&#xff09;是一个由国际标准化组织&#xff08;ISO&#xff09;和国际电报电话咨询委员会&#xff08;CCITT&#xff09;联合制定的网络通信协议规范&#xff0c;它将网络通信分为七个不…

React antd tree树组件 - 父子节点没有自动关联情况下 - 显示半选、全选状态以及实现父子节点互动

实现的效果图如下&#xff1a; 如Ant Design Vue 中所示&#xff0c;并没有提供获取半选节点的方法&#xff0c;当设置checked和checkStrictly时&#xff0c;父子节点也不再自动关联了 前提&#xff1a;从后端可以获取的数据分别是完整的树型数据、所有选中的节点数据&#…

在pycharm中对使用脚本文件运行的程序进行调试

在github中下载的许多项目都可以使用给出的脚本文件运行&#xff0c;本文介绍如果在pycharm中对使用脚本文件运行的程序进行调试的方法。 1.点击 edit configurations 2.选择要debug的py文件&#xff0c;并且填写参数 3.点击运行旁边的debug按钮

odoo16 tree视图没有导出按钮

odoo16 tree视图没有导出按钮 做了一个odoo应用,很奇怪,同样的角色,不同的用户,有些有导出按钮,有些没有,一直没搞清楚为啥, 今天刚好有时间,好好研究一下. 1 先按浏览器F12,导出按钮对应的html: <button type"button" class"btn btn-secondary fa fa-dow…

理解持续测试,才算理解DevOps

软件产品的成功与否&#xff0c;在很大程度上取决于对市场需求的及时把控&#xff0c;采用DevOps可以加快产品交付速度&#xff0c;改善用户体验&#xff0c;从而有助于保持领先于竞争对手的优势。 作为敏捷开发方法论的一种扩展&#xff0c;DevOps强调开发、测试和运维不同团队…

使用BP插件captcha-killer识别图片验证码绕过系统验证码机制

使用BP插件captcha-killer绕过验证码 前置条件 1、下载安装插件 burp2020前使用&#xff1a;https://github.com/c0ny1/captcha-killer/tree/0.1.2 burp2020后使用&#xff1a;https://github.com/Ta0ing/captcha-killer-java8 2、导入插件 分为三个部分&#xff1a;上面为验…

【Sklearn】基于朴素贝叶斯算法的数据分类预测(Excel可直接替换数据)

【Sklearn】基于朴素贝叶斯算法的数据分类预测&#xff08;Excel可直接替换数据&#xff09; 1.模型原理2.模型参数3.文件结构4.Excel数据5.下载地址6.完整代码7.运行结果 1.模型原理 模型原理&#xff1a; 朴素贝叶斯分类是基于贝叶斯定理的一种分类方法。它假设特征之间相互…

【一定要会】为ChatGPT插上翅膀的5个常用插件!

自从ChatGPT接入插件功能后&#xff0c;便不再受限于预训练数据中的知识&#xff0c;第三方开发者也可以基于ChatGPT增强自家应用程序的功能。自此 ChatGPT更像是一个开放的平台甚至是生态了。 截止的今年的7月20日&#xff0c;ChatGPT已经接入了700多个插件&#xff08;当然&…

智能驾驶系列报告之一:智能驾驶 ChatGPT时刻有望来临

原创 | 文 BFT机器人 L3 功能加速落地&#xff0c;政策标准有望明确 L2 发展日益成熟&#xff0c;L3 功能加速落地。根据市场监管总局发布的《汽车驾驶自动化分级》与 SAE发布的自动驾驶分级标准&#xff0c;自动驾驶主要分为 6 个级别&#xff08;0 级到 5 级&#xff0c;L0 …

五、linux系统下创建新目录的mkdir命令

mkdir命令 在Linux系统中&#xff0c;如果想要创建一个新目录&#xff0c;即文件夹&#xff0c;可以使用mkdir命令&#xff1a; 1、语法&#xff1a;mkdir [-p](可以不存在) Linux路径(必须存在) 2、基础操作&#xff1a;mkdir 目录名 &#xff08;1&#xff09;方法一&…