Java正则表达式基础

简介: Java正则表达式基础

(一)正则表达式是什么,用来干什么:


正则表达式(regularexpression,简写为regex)是一个字符串,用来描述匹配一个字符申集合的模式。对于字符串处理来说,正则表达式是一个强大的工具。


可以使用正则表达式来匹配、替换和拆分字符串。在生活中我们经常会需要编写代码来验证用户输入,比如验证输入是否是一个数字,是否是一个全部小写的字符串,或者社会安全号。这时我们可以使用正则表达式来完成这个任务。在网络安全上,正则表达式常被用作过滤用户输入,防止用户输入恶意代码等,起到防护作用。(如今已经不常见了)


(二)前置知识:


使用正则表达式需要引入 java.util.regex.* 包(其实正常直接import java.util.*  个人觉得省事),包里包含了三个类Pattern 类、Matcher 类、PatternSyntaxException。


在 Java 中,\\表示:我要插入一个正则表达式的反斜线,所以其后的字符具有特殊的意义。而在其他语言中,\\表示:我想要在正则表达式中插入一个普通的(字面上的)反斜杠,请不要给它任何特殊的意义。


\:将下一字符标记为特殊字符、文本、反向引用或八进制转义符。例如, n匹配字符 n。\n 匹配换行符。序列 \\\\ 匹配 \\ ,\\( 匹配 (。


^:匹配输入字符串开始的位置。如果设置了 RegExp 对象的 Multiline 属性,^ 还会与"\n"或"\r"之后的位置匹配。


$:匹配输入字符串结尾的位置。如果设置了 RegExp 对象的 Multiline 属性,$ 还会与"\n"或"\r"之前的位置匹配。


注意:


^:只有当它出现在一个字符集合里(被放在[和]之间)并紧跟在左方括号[的后面时,它才能发挥“求非”作用。如果是在一个字符集合的外面并位于一个模式的开头,^将匹配字符串的开头。


例如:[^abc]: 表示不是a,b,c中的任意一个;


(三)常用方法:


①匹配


String.matches() 这个方法主要是返回是否匹配指定的字符串,如果匹配则为 true,反之为 false。


matches方法很类似equa1s方法。然而,matches方法功能更加强大。它不仅可以匹配一个固定的字符串,还可以匹配符合一个模式的字符串集。


②分割


String[] split(String regex)

743e9171e5c5f229903377c5e24c3f82.png


③替换

replaceFirst()和replaceAll()方法都用来替换匹配给定正则表达式的文本。

正如其名称所示,replaceFirst()替换第一个匹配项,replaceAll()替换所有匹配项。

(四)语法:


①字符的取值范围


[abc] : 表示可能是a,可能是b,也可能是c。


[^abc]: 表示不是a,b,c中的任意一个


[a-zA-Z]: 表示是英文字母


[0-9]:表示是数字


②字符表示


.:匹配任意的字符,除了换行符。


\d:表示数字


\D:表示非数字


\s:表示由空格组成,[ \t\n\r\x\f]


\S:表示由非空字符组成,[^\s]


\w:表示字母、数字、下划线,[a-zA-Z0-9_]


\W:表示不是由字母、数字、下划线组成


\b:匹配一个字边界,即字与空格间的位置。例如,"er\b"匹配"never"中的"er",但不匹配"verb"中的"er"。


\B:非字边界匹配。"er\B"匹配"verb"中的"er",但不匹配"never"中的"er"。


③数量表达式


?: 表示出现0次或1次,同下+和*,跟在字母或者.点号后面。


+: 表示出现1次或多次


*: 表示出现0次、1次或多次


{n}:表示出现n次


{n,m}:表示出现n~m次


{n,}:表示出现n次或n次以上


贪心与非贪心:


?:当此字符紧随任何其他限定符(*、+、?、{n}、{n,}、{n,m})之后时,匹配模式是"非贪心的"。"非贪心的"模式匹配搜索到的、尽可能短的字符串,而默认的"贪心的"模式匹配搜索到的、尽可能长的字符串。例如,在字符串"oooo"中,"o+?"只匹配单个"o",而"o+"匹配所有"o"。


注意:*, +, {n,}都是常用的贪婪型元字符,在匹配时它们会尽可能地从一段文本的开头一直匹配到这段文本的末尾,而不是从这段文本的开头匹配到碰到第一个匹配时为止。


④逻辑表达式


XY: 表示X后面跟着Y,这里X和Y分别是正则表达式的一部分


X|Y:表示X或Y,比如"food|f"匹配的是foo(d或f),而"(food)|f"匹配的是food或f


(X):子表达式,将X看做是一个整体


表如下:


(五)实例:


①校验数字的表达式


数字:^[0-9]*$


n位的数字:^\d{n}$


至少n位的数字:^\d{n,}$


m-n位的数字:^\d{m,n}$


零和非零开头的数字:^(0|[1-9][0-9]*)$


非零开头的最多带两位小数的数字:^([1-9][0-9]*)+(\.[0-9]{1,2})?$


带1-2位小数的正数或负数:^(\-)?\d+(\.\d{1,2})$


正数、负数、和小数:^(\-|\+)?\d+(\.\d+)?$


有两位小数的正实数:^[0-9]+(\.[0-9]{2})?$


有1~3位小数的正实数:^[0-9]+(\.[0-9]{1,3})?$


非零的正整数:^[1-9]\d*$ 或 ^([1-9][0-9]*){1,3}$ 或 ^\+?[1-9][0-9]*$


非零的负整数:^\-[1-9][]0-9"*$ 或 ^-[1-9]\d*$


非负整数:^\d+$ 或 ^[1-9]\d*|0$


非正整数:^-[1-9]\d*|0$ 或 ^((-\d+)|(0+))$


非负浮点数:^\d+(\.\d+)?$ 或 ^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0$


非正浮点数:^((-\d+(\.\d+)?)|(0+(\.0+)?))$ 或 ^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0+|0$


正浮点数:^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$ 或 ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$


负浮点数:^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$ 或 ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$


浮点数:^(-?\d+)(\.\d+)?$ 或 ^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$


②校验字符的表达式


汉字:^[\u4e00-\u9fa5]{0,}$    //涉及到编码了


英文和数字:^[A-Za-z0-9]+$


长度为3-20的所有字符:^.{3,20}$


由26个英文字母组成的字符串:^[A-Za-z]+$


由26个大写英文字母组成的字符串:^[A-Z]+$


由26个小写英文字母组成的字符串:^[a-z]+$


由数字和26个英文字母组成的字符串:^[A-Za-z0-9]+$


由数字、26个英文字母或者下划线组成的字符串:^\w+$ 或 ^\w{3,20}$


中文、英文、数字包括下划线:^[\u4E00-\u9FA5A-Za-z0-9_]+$


中文、英文、数字但不包括下划线等符号:^[\u4E00-\u9FA5A-Za-z0-9]+$ 或 ^[\u4E00-\u9FA5A-Za-z0-9]{2,20}$


可以输入含有^%&',;=?$\"等字符:[^%&',;=?$\x22]+


禁止输入含有~的字符:[^~\x22]+


③真实实例


Email地址:^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$


域名:[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(\.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+\.?


InternetURL:[a-zA-z]+://[^\s]* 或 ^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$


手机号码:^(13[0-9]|14[5|7]|15[0|1|2|3|4|5|6|7|8|9]|18[0|1|2|3|5|6|7|8|9])\d{8}$


电话号码:^(\(\d{3,4}-)|\d{3.4}-)?\d{7,8}$


国内电话号码:\d{3}-\d{8}|\d{4}-\d{7}


身份证号(15位、18位数字),最后一位是校验位,可能为数字或字符X:(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)


帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$


密码(以字母开头,长度在6~18之间,只能包含字母、数字和下划线):^[a-zA-Z]\w{5,17}$


强密码(必须包含大小写字母和数字的组合,不能使用特殊字符,长度在 8-10 之间):^(?=.*\d)(?=.*[a-z])(?=.*[A-Z])[a-zA-Z0-9]{8,10}$


强密码(必须包含大小写字母和数字的组合,可以使用特殊字符,长度在8-10之间):^(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,10}$


日期格式:^\d{4}-\d{1,2}-\d{1,2}


一年的12个月(01~09和1~12):^(0?[1-9]|1[0-2])$


一个月的31天(01~09和1~31):^((0?[1-9])|((1|2)[0-9])|30|31)$


xml文件:^([a-zA-Z]+-?)+[a-zA-Z0-9]+\\.[x|X][m|M][l|L]$


中文字符的正则表达式:[\u4e00-\u9fa5]


双字节字符:[^\x00-\xff] (包括汉字在内,可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1))


空白行的正则表达式:\n\s*\r (可以用来删除空白行)


HTML标记的正则表达式:<(\S*?)[^>]*>.*?|<.*? /> ( 首尾空白字符的正则表达式:^\s*|\s*$或(^\s*)|(\s*$) (可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式)


腾讯QQ号:[1-9][0-9]{4,} (腾讯QQ号从10000开始)


中国邮政编码:[1-9]\d{5}(?!\d) (中国邮政编码为6位数字)


IP地址:((?:(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d)\\.){3}(?:25[0-5]|2[0-4]\\d|[01]?\\d?\\d))

目录
相关文章
|
21天前
|
安全 Java API
Java中的Lambda表达式:简洁与功能的结合
Java中的Lambda表达式:简洁与功能的结合
172 91
|
21天前
|
安全 Java
Java中的Switch表达式:更简洁的多路分支
Java中的Switch表达式:更简洁的多路分支
192 91
|
2月前
|
自然语言处理 Java Apache
在Java中将String字符串转换为算术表达式并计算
具体的实现逻辑需要填写在 `Tokenizer`和 `ExpressionParser`类中,这里只提供了大概的框架。在实际实现时 `Tokenizer`应该提供分词逻辑,把输入的字符串转换成Token序列。而 `ExpressionParser`应当通过递归下降的方式依次解析
183 14
|
1月前
|
Java 编译器
Java 17 Switch表达式:更简洁、更强大的流程控制
Java 17 Switch表达式:更简洁、更强大的流程控制
|
2月前
|
设计模式 数据采集 Java
Java正则表达式的基础知识,进阶至熟练掌握。
通过大量的练习来熟悉它们的识别模式、如何设计模式来解决实际问题,才能够逐步达到熟练掌握。更多的是通过实践、编写代码和解决真实问题来完善技能。在这方面,没有快速的捷径,唯有刻意练习和长时间的代码实践。
57 0
|
3月前
|
SQL JSON 安全
Java 8 + 中 Lambda 表达式与 Stream API 的应用解析
摘要:本文介绍了Java 8+核心新特性,包括Lambda表达式与Stream API的集合操作(如过滤统计)、函数式接口的自定义实现、Optional类的空值安全处理、接口默认方法与静态方法的扩展能力,以及Java 9模块化系统的组件管理。每个特性均配有典型应用场景和代码示例,如使用Stream统计字符串长度、Optional处理Map取值、模块化项目的依赖声明等,帮助开发者掌握现代Java的高效编程范式。(150字)
62 1
|
5月前
|
缓存 监控 Java
深入解析java正则表达式
本文深入解析Java正则表达式的应用,从基础概念到实际开发技巧全面展开。正则表达式是一种强大的文本处理工具,广泛应用于格式验证、搜索替换等场景。Java通过`Pattern`和`Matcher`类支持正则表达式,`Pattern.compile()`方法将正则字符串编译为高效模式对象。文章详细介绍了核心类的功能、常用正则语法及实际案例(如邮箱和电话号码验证)。掌握这些内容,可显著提升文本处理能力,满足多种开发需求。
174 1
|
6月前
|
SQL Rust Java
怎么理解Java中的lambda表达式
Lambda表达式是JDK8引入的新语法,用于简化匿名内部类的代码写法。其格式为`(参数列表) -&gt; { 方法体 }`,适用于函数式接口(仅含一个抽象方法的接口)。通过Lambda表达式,代码更简洁灵活,提升Java的表达能力。
112 4
|
6月前
|
SQL IDE 算法
《从头开始学java,一天一个知识点》之:运算符与表达式:算术、比较和逻辑运算
**你是否也经历过这些崩溃瞬间?** - 看了三天教程,连`i++`和`++i`的区别都说不清 - 面试时被追问&quot;`a==b`和`equals()`的区别&quot;,大脑突然空白 - 写出的代码总是莫名报NPE,却不知道问题出在哪个运算符 这个系列为你打造Java「速效救心丸」,每天1分钟,地铁通勤、午休间隙即可完成学习。直击高频考点和实际开发中的「坑位」,拒绝冗长概念,每篇都有可运行的代码示例。明日预告:《控制流程:if-else条件语句实战》。
104 6

热门文章

最新文章