深入解析Java正则表达式:定义、原理和实例
1.前言
1.1简介
正则表达式在Java开发中扮演着重要的角色。本文将详细讲解Java正则表达式的定义、工作原理,并提供一些实例和示例代码,帮助读者更好地理解和应用正则表达式
1.2使用场景的介绍
正则表达式适用于许多问题和场景,包括但不限于以下几个方面:
数据验证和提取:可以使用正则表达式来验证输入数据的格式是否符合要求。例如,验证邮箱地址、手机号码、身份证号码等。同时,也可以使用正则表达式从一段文本中提取出需要的信息,如提取URL、日期、数字等。
数据处理和替换:正则表达式可以用于对文本进行搜索、替换和修改。例如,可以使用正则表达式进行敏感词过滤、关键词替换、 HTML标签去除等。
网络爬虫和数据抽取:在网络爬虫和数据抽取中,正则表达式常被用来从HTML、XML等文档中抽取有用的信息。通过匹配特定的模式,可以提取出需要的数据。
日志分析和处理:在日志分析和处理中,正则表达式可以帮助解析日志文件并提取所需的信息。例如,从服务器日志中提取访问IP、时间、URL等。
文本搜索和匹配:正则表达式可以用于文本搜索和匹配,快速定位匹配特定模式的字符串。可以在文本编辑器、代码编辑器、命令行工具中使用正则表达式来查找并操作特定的文本。
总之,正则表达式是一个强大而灵活的工具,可以应用于各种领域和场景,用于处理和操作文本、数据、日志等。但需要注意的是,在处理复杂的结构化数据时,正则表达式可能存在一定的局限性,此时可能需要考虑其他更适合的解析器或工具。
2.正则表达式的定义
2.1 什么是正则表达式
正则表达式是一种用于匹配、查找和操作字符串的强大工具。它是一种描述字符串模式的表达式,可以用来进行字符串的匹配、替换、提取等操作
2.2 正则表达式的基本语法

- 字符匹配:普通字符(a-z、A-Z、0-9)表示匹配对应字符;在正则表达式中的特殊字符需要使用反斜杠进行转义,例如"."表示匹配一个点号。
- 字符类:用方括号([])表示,可以匹配其中任意一个字符。例如"[abc]"表示匹配字符a、b或c。
- 数量词:用于确定前面的元素出现的次数。常见的数量词包括"*"(零个或多个)、"+"(一个或多个)、"?"(零个或一个)等。
- 边界匹配:"^"表示字符串的开头,"$"表示字符串的结尾。
- 分组:用小括号()将多个元素组合成一个整体。可以使用分组来控制元素的顺序、应用数量词,并且可以通过分组来提取匹配的内容。
2.3 Java中的正则表达式支持
Pattern:用于编译和处理正则表达式的对象。Matcher:用于进行正则表达式匹配、查找和操作的对象。PatternSyntaxException:在解析或编译正则表达式时,如果表达式有语法错误,将抛出该异常。Java中的正则表达式支持灵活且功能强大,可以满足各种字符串处理需求。可以通过
Pattern和Matcher类的方法来匹配、提取和替换字符串,以及进行其他复杂的字符串操作。
matches(String regex):检查整个字符串是否匹配正则表达式。split(String regex):根据正则表达式将字符串拆分为字符串数组。replaceAll(String regex, String replacement):使用指定的替换字符串替换匹配正则表达式的部分。find():在当前位置和后续位置寻找匹配正则表达式的部分。
3正则表达式的原理
3.1 匹配和查找
在正则表达式中,匹配是指用正则表达式来检查一个字符串是否符合某种模式。查找是指在一个字符串中通过正则表达式查找匹配某种模式的子串。
3.2 正则表达式的模式匹配引擎
正则表达式引擎是用于实现正则表达式匹配和查找的软件模块。不同的编程语言和工具使用的正则表达式引擎可能不同,但它们通常遵循基本的正则表达式语法和实现原理。
常见的正则表达式引擎包括:
- NFA(非确定有限自动机)引擎:该引擎使用NFA来实现正则表达式的匹配。它采用了一种“尽可能多地匹配”的策略,也称为贪婪匹配。Java原生的正则表达式引擎就是基于NFA实现的。
- DFA(确定有限自动机)引擎:该引擎使用DFA来实现正则表达式的匹配。它采用了一种“尽可能少地匹配”的策略,也称为非贪婪匹配。Perl和Python中的正则表达式引擎都是基于DFA实现的。
- backtracking引擎:该引擎使用回溯算法实现正则表达式的匹配。它通过不断回退和尝试来搜索所有可能的匹配。该引擎支持贪婪和非贪婪匹配,并且可以处理比较复杂的正则表达式。在Java中,可以使用
Pattern.COMMENTS | Pattern.DOTALL标记指定使用backtracking引擎。
3.3 分组和捕获
正则表达式引擎是用于实现正则表达式匹配和查找的软件模块。不同的编程语言和工具使用的正则表达式引擎可能不同,但它们通常遵循基本的正则表达式语法和实现原理。
常见的正则表达式引擎包括:
- NFA(非确定有限自动机)引擎:该引擎使用NFA来实现正则表达式的匹配。它采用了一种“尽可能多地匹配”的策略,也称为贪婪匹配。Java原生的正则表达式引擎就是基于NFA实现的。
- DFA(确定有限自动机)引擎:该引擎使用DFA来实现正则表达式的匹配。它采用了一种“尽可能少地匹配”的策略,也称为非贪婪匹配。Perl和Python中的正则表达式引擎都是基于DFA实现的。
- backtracking引擎:该引擎使用回溯算法实现正则表达式的匹配。它通过不断回退和尝试来搜索所有可能的匹配。该引擎支持贪婪和非贪婪匹配,并且可以处理比较复杂的正则表达式。在Java中,可以使用
Pattern.COMMENTS | Pattern.DOTALL标记指定使用backtracking引擎。
3.4 贪婪和非贪婪匹配
贪婪匹配是指在匹配时尽可能多地匹配,直到无法继续匹配为止。例如,正则表达式
.*foo会匹配尽可能多的字符,直到最后一个"foo"出现为止。非贪婪匹配是指在匹配时尽可能少地匹配,直到满足条件为止。例如,正则表达式
.*?foo会匹配尽可能少的字符,直到第一个"foo"出现为止。在Java中,可以使用"?","*?"和"+?"来指定非贪婪匹配。例如,正则表达式
.*?foo可以匹配任意字符,直到第一个"foo"出现为止。
3.实例与代码解析
3.1 验证邮箱地址
import java.util.regex.Pattern;public class EmailValidator {private static final String EMAIL_PATTERN = "^\\w+([.-]?\\w+)*@\\w+([.-]?\\w+)*(\\.\\w{2,3})+$";public static boolean validateEmail(String email) {return Pattern.matches(EMAIL_PATTERN, email);}public static void main(String[] args) {String email = "example@example.com";boolean isValid = validateEmail(email);System.out.println("Is email valid? " + isValid);}
}
3.2 匹配手机号码
import java.util.regex.Matcher;
import java.util.regex.Pattern;public class PhoneNumberMatcher {private static final String PHONE_PATTERN = "^(\\+\\d{1,3})?\\s?(\\d{1,4})?[\\s.-]?\\(?(\\d{1,3})?\\)?[\\s.-]?\\d{1,4}[\\s.-]?\\d{1,9}$";public static boolean matchPhoneNumber(String phoneNumber) {Pattern pattern = Pattern.compile(PHONE_PATTERN);Matcher matcher = pattern.matcher(phoneNumber);return matcher.matches();}public static void main(String[] args) {String phoneNumber = "+1 123-456-7890";boolean isMatched = matchPhoneNumber(phoneNumber);System.out.println("Is phone number matched? " + isMatched);}
}
3.3 提取HTML标签中的内容
import java.util.regex.Matcher;
import java.util.regex.Pattern;public class PhoneNumberMatcher {private static final String PHONE_PATTERN = "^(\\+\\d{1,3})?\\s?(\\d{1,4})?[\\s.-]?\\(?(\\d{1,3})?\\)?[\\s.-]?\\d{1,4}[\\s.-]?\\d{1,9}$";public static boolean matchPhoneNumber(String phoneNumber) {Pattern pattern = Pattern.compile(PHONE_PATTERN);Matcher matcher = pattern.matcher(phoneNumber);return matcher.matches();}public static void main(String[] args) {String phoneNumber = "+1 123-456-7890";boolean isMatched = matchPhoneNumber(phoneNumber);System.out.println("Is phone number matched? " + isMatched);}
}
3.4 替换字符串中的特定字符
import java.util.regex.Pattern;public class StringReplacer {public static String replaceString(String input, String pattern, String replacement) {return input.replaceAll(pattern, replacement);}public static void main(String[] args) {String input = "Hello, world!";String pattern = "world";String replacement = "Java";String replacedString = replaceString(input, pattern, replacement);System.out.println("Replaced string: " + replacedString);}
}
3.5 获取URL中的参数值
import java.util.regex.Matcher;
import java.util.regex.Pattern;public class URLParameterExtractor {private static final String PARAMETER_PATTERN = "(?<=\\?|&)(\\w+)=(\\w+)";public static void extractURLParameters(String url) {Pattern pattern = Pattern.compile(PARAMETER_PATTERN);Matcher matcher = pattern.matcher(url);while (matcher.find()) {String parameter = matcher.group(1);String value = matcher.group(2);System.out.println(parameter + ": " + value);}}public static void main(String[] args) {String url = "https://www.example.com?name=John&age=25";extractURLParameters(url);}
}
相关文章:
深入解析Java正则表达式:定义、原理和实例
1.前言 1.1简介 正则表达式在Java开发中扮演着重要的角色。本文将详细讲解Java正则表达式的定义、工作原理,并提供一些实例和示例代码,帮助读者更好地理解和应用正则表达式 1.2使用场景的介绍 正则表达式适用于许多问题和场景,包括但不限于…...
DatenLord前沿技术分享 No.38
达坦科技专注于打造新一代开源跨云存储平台DatenLord,通过软硬件深度融合的方式打通云云壁垒,致力于解决多云架构、多数据中心场景下异构存储、数据统一管理需求等问题,以满足不同行业客户对海量数据跨云、跨数据中心高性能访问的需求。在本周…...
ms-sql server sql 把逗号分隔的字符串分开
案例: sql 查询-字段里是逗号,分隔开的数组,查询匹配数据 sql 查询-字段里是逗号,分隔开的数组,查询匹配数据_sql server 数组匹配-CSDN博客 SQL SERVER 把逗号隔开的字符串拆分成行 SQL SERVER 把逗号隔开的字符串拆分成行_sqlserver拆分…...
零基础制作预约小程序,微信小程序预约服务指南
随着互联网的发展,越来越多的服务开始转移到线上。预约服务也是其中之一。通过微信小程序,商家可以提供更加便捷的预约服务,让客户随时随地预约商品或服务。本文将介绍如何零基础制作预约小程序,包括使用第三方制作平台、选择合适…...
算法---交替合并字符串
题目 给你两个字符串 word1 和 word2 。请你从 word1 开始,通过交替添加字母来合并字符串。如果一个字符串比另一个字符串长,就将多出来的字母追加到合并后字符串的末尾。 返回 合并后的字符串 。 示例 1: 输入:word1 “abc”…...
下载运行ps软件提示因为计算机中丢失d3dcompiler_47.dll解决方法
在计算机系统中,DLL文件(动态链接库)是一种重要的共享库,它包含了可被多个程序使用的代码和数据。然而,当某些DLL文件丢失或损坏时,可能会导致程序无法正常运行。本文将介绍四种解决D3DCompiler_47.dll缺失…...
Flutter Image组件如何处理图片加载过程中的错误?
在Flutter中,Image组件可以通过监听加载过程中的错误来处理图片加载过程中的错误。 新一代ChatGpt智能助手 文客微创 具体来说,可以使用Image.network或Image.asset方法加载图片,并使用Builder模式来监听图片加载过程中的状态。 例如&…...
在mysql8查询中使用ORDER BY结合LIMIT时,分页查询时出现后一页的数据重复前一页的部分数据。
这里写目录标题 问题描述:问题模拟:原因分析问题解释问题解决验证官方文档支持 问题描述: 在mysql8查询中使用ORDER BY结合LIMIT时,分页查询时出现后一页的数据重复前一页的部分数据。 问题模拟: 表table_lock_test&…...
【SA8295P 源码分析 (三)】97 - QNX AIS Camera 框架介绍 及 Camera 工作流程分析
【SA8295P 源码分析】97 - QNX AIS Camera 框架介绍 及 Camera 工作流程分析 一、QNX AIS Server 框架分析二、QNX Hypervisor / Android GVM 方案介绍三、Camera APP 调用流程分析四、QCarCam 状态转换过程介绍五、Camera 加串-解串 硬件链路分析六、摄像头初始化检测过程介绍…...
基于epoll封装非阻塞的reactor框架(附源码)
C++常用功能源码系列 文章目录 C++常用功能源码系列前言一、reactor架构二、client端reactor代码三、server端reactor代码四、单reactor架构可以实现百万并发总结前言 本文是C/C++常用功能代码封装专栏的导航贴。部分来源于实战项目中的部分功能提炼,希望能够达到你在自己的项…...
安装Git和git命令使用
文章目录 安装Git创建版本库版本回退工作区和暂存区管理修改撤销修改 安装Git 在Windows上安装Git 在Windows上使用Git,可以从Git官网直接下载安装程序,然后按默认选项安装即可。 安装完成后,在开始菜单里找到“Git”->“Git Bash”&…...
【SA8295P 源码分析 (四)】65 - emac0-phy 与 emac1-switch兼容 方案实现
【SA8295P 源码分析】65 - emac0-phy 与 emac1-switch兼容 方案实现 系列文章汇总见:《【SA8295P 源码分析 (四)】网络模块 文章链接汇总 - 持续更新中》 本文链接:《【SA8295P 源码分析 (四)】65 - emac0-phy 与 emac1-switch兼容 方案实现》 本文在前文《【SA8295P 源码分析…...
SpringSecurity源码学习二:异常处理
目录 1. 原理2. 组件3. ExceptionTranslationFilter3.1 默认过滤器顺序3.2 ExceptionTranslationFilter源码3.2.1 AuthenticationException异常3.2.2 AccessDeniedException异常 总结 1. 原理 Spring Security 异常处理的原理是通过一系列的异常处理器来处理在安全验证和授权过…...
代码随想录算法训练营第23期day28|491.递增子序列 46.全排列 47.全排列 II
目录 一、(leetcode 491)递增子序列 二、(leetcode 46)全排列 三、(leetcode 47)全排列 II 一、(leetcode 491)递增子序列 力扣题目链接 状态:去重方法错误。 这道题…...
ubuntu磁盘扩容
1、参考链接: https://blog.csdn.net/qq_43265072/article/details/112312223 2、尝试过程中小心翼翼,生怕待会系统崩掉,要重装。。。 不过呢有撤销和提交按钮就非常贴心,如果稍有不慎就一路回撤就好啦 说一下怎么移动空间&…...
C/S架构学习之使用select实现TCP小型并发服务器
select实现TCP小型并发服务器的流程:一、创建套接字(socket函数):通信域选择IPV4网络协议、套接字类型选择流式; int sockfd socket(AF_INET,SOCK_STREAM,0); //通信域选择IPV4、套接字类型选择流式二、填充服务器的网…...
公司注册类型分类标准是怎样的
公司法上的分支机构、分公司、子公司是什么 - 公司法 (一)以公司股东的责任范围为标准分类 以公司股东的责任范围为标准,亦即以公司股东是否对公司债务承担责任为标准,可将公司分为无限责任公司、两合公司、股份两合公司、股份有限公司和有限责任公司。…...
5.MidBook项目经验之MongoDB,Nacos,网关
1.医院查询接口 //系统1(signsignMD5加密后) ----> 系统2(数据库signMD5加密 相对比),好处在于网络之间传输不会得到直接得到sign 2.上传和删除科室信息 //map转jsonString,然后再转为对象//保存需要查数据库是否存在,存在修改,不存在添加//接口的包引入不对导致调用引包错误…...
XMLHttpRequest对象的Get请求和Post请求的用法
XMLHttpRequest对象的Get请求和Post请求的用法 Get请求提交数据 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>发送ajax get请求</title> </head> <body> <script type"…...
Tomcat动静分离
访问静态页面和访问动态页面分开,实现动态页面和静态页面的负载均衡 一、七层动静分离 3台虚拟机 1、nginx1既是代理也是静态 nginx1:20.0.0.11 2、请求动态页面:Tomcat1和Tomcat2 Tomcat1:20.0.0.31 Tomcat2:20…...
使用VSCode开发Django指南
使用VSCode开发Django指南 一、概述 Django 是一个高级 Python 框架,专为快速、安全和可扩展的 Web 开发而设计。Django 包含对 URL 路由、页面模板和数据处理的丰富支持。 本文将创建一个简单的 Django 应用,其中包含三个使用通用基本模板的页面。在此…...
React第五十七节 Router中RouterProvider使用详解及注意事项
前言 在 React Router v6.4 中,RouterProvider 是一个核心组件,用于提供基于数据路由(data routers)的新型路由方案。 它替代了传统的 <BrowserRouter>,支持更强大的数据加载和操作功能(如 loader 和…...
前端倒计时误差!
提示:记录工作中遇到的需求及解决办法 文章目录 前言一、误差从何而来?二、五大解决方案1. 动态校准法(基础版)2. Web Worker 计时3. 服务器时间同步4. Performance API 高精度计时5. 页面可见性API优化三、生产环境最佳实践四、终极解决方案架构前言 前几天听说公司某个项…...
如何在看板中有效管理突发紧急任务
在看板中有效管理突发紧急任务需要:设立专门的紧急任务通道、重新调整任务优先级、保持适度的WIP(Work-in-Progress)弹性、优化任务处理流程、提高团队应对突发情况的敏捷性。其中,设立专门的紧急任务通道尤为重要,这能…...
LINUX 69 FTP 客服管理系统 man 5 /etc/vsftpd/vsftpd.conf
FTP 客服管理系统 实现kefu123登录,不允许匿名访问,kefu只能访问/data/kefu目录,不能查看其他目录 创建账号密码 useradd kefu echo 123|passwd -stdin kefu [rootcode caozx26420]# echo 123|passwd --stdin kefu 更改用户 kefu 的密码…...
Java求职者面试指南:计算机基础与源码原理深度解析
Java求职者面试指南:计算机基础与源码原理深度解析 第一轮提问:基础概念问题 1. 请解释什么是进程和线程的区别? 面试官:进程是程序的一次执行过程,是系统进行资源分配和调度的基本单位;而线程是进程中的…...
pikachu靶场通关笔记19 SQL注入02-字符型注入(GET)
目录 一、SQL注入 二、字符型SQL注入 三、字符型注入与数字型注入 四、源码分析 五、渗透实战 1、渗透准备 2、SQL注入探测 (1)输入单引号 (2)万能注入语句 3、获取回显列orderby 4、获取数据库名database 5、获取表名…...
Pydantic + Function Calling的结合
1、Pydantic Pydantic 是一个 Python 库,用于数据验证和设置管理,通过 Python 类型注解强制执行数据类型。它广泛用于 API 开发(如 FastAPI)、配置管理和数据解析,核心功能包括: 数据验证:通过…...
STM32标准库-ADC数模转换器
文章目录 一、ADC1.1简介1. 2逐次逼近型ADC1.3ADC框图1.4ADC基本结构1.4.1 信号 “上车点”:输入模块(GPIO、温度、V_REFINT)1.4.2 信号 “调度站”:多路开关1.4.3 信号 “加工厂”:ADC 转换器(规则组 注入…...
在Spring Boot中集成RabbitMQ的完整指南
前言 在现代微服务架构中,消息队列(Message Queue)是实现异步通信、解耦系统组件的重要工具。RabbitMQ 是一个流行的消息中间件,支持多种消息协议,具有高可靠性和可扩展性。 本博客将详细介绍如何在 Spring Boot 项目…...
