1、常用的正则表达式

 预定义字符类:
任何字符(与行结束符可能匹配也可能不匹配)
\d  数字:[0-9]
\D  非数字: [^0-9]
\s  空白字符:[ \t\n\x0B\f\r]
\S  非空白字符:[^\s]
\w  单词字符:[a-zA-Z_0-9]
\W  非单词字符:[^\w]

数量词:
X?  X,一次或一次也没有
X*  X,零次或多次
X+  X,一次或多次
X{n}  X,恰好 n 次
X{n,}  X,至少 n 次
X{n,m}  X,至少 n 次,但是不超过 m 次

字符类 :(范围)
[abc]  a、b 或 c(简单类)
[^abc]  任何字符,除了 a、b 或 c(否定)
[a-zA-Z]  a 到 z 或 A 到 Z,两头的字母包括在内(范围)
[a-d[m-p]]  a 到 d 或 m 到 p:[a-dm-p](并集)
[a-z&&[def]]  d、e 或 f(交集)
[a-z&&[^bc]]  a 到 z,除了 b 和 c:[ad-z](减去)
[a-z&&[^m-p]]  a 到 z,而非 m 到 p:[a-lq-z](减去)

2、实例

 package com.dhb.pattern;

 /**
* @author DSHORE / 2018-5-31
*
*/
public class Demo1 {//注意: \ 表示:转义字符,所以下面有一个\的,都要再加上一个\。比如:要想输出\d的效果,就必须要以\\d的形式输出才行
public static void main(String[] args) {//matches():匹配 判断前面的字符,是否匹配后面的字符
//预定义字符类
System.out.println("a".matches("."));//返回值:true 说明:.是匹配a的,即.=a
System.out.println("aa".matches("."));//返回值:false 说明:.表示 一个字符,而aa是两个字符
System.out.println(" ".matches("."));//返回值:true 说明:空格也是匹配a的,即空格=a
System.out.println("".matches("."));//返回值:true System.out.println("".matches("\\d"));//返回值:true 说明:\d表示 数字:[0-9]
System.out.println("".matches("\\d"));//返回值:false 说明:\d表示 一个字符,而10是两个字符
System.out.println("".matches("\\d"));//返回值:true
System.out.println("a".matches("\\d"));//返回值:false 说明:a不是数字字符 System.out.println("a".matches("\\D"));//返回值:true 说明:\D表示 非数字: [^0-9]
System.out.println("aa".matches("\\D"));//返回值:false 说明:\D表示 一个字符,而aa是两个字符
System.out.println("".matches("\\D"));//返回值:false
System.out.println("".matches("\\D"));//返回值:false System.out.println("\t".matches("\\s"));//返回值:true 说明:\s表示 空白字符:[ \t\n\x0B\f\r]
System.out.println(" ".matches("\\s"));//返回值:true
System.out.println("a".matches("\\s"));//返回值:false
System.out.println("".matches("\\s"));//返回值:false System.out.println("a".matches("\\S"));//返回值:true 说明:\S表示 非空白字符:[^\s]
System.out.println("aa".matches("\\S"));//返回值:false 说明:\S表示 一个字符,而aa是两个字符
System.out.println(" ".matches("\\S"));//返回值:false 说明:" "是空白字符 System.out.println("@".matches("\\w"));//返回值:false 说明:\w表示 单词字符:[a-zA-Z_0-9]
System.out.println("".matches("\\w"));//返回值:true
System.out.println("".matches("\\w"));//返回值:false 说明:\w表示 一个字符,而10是两个字符
System.out.println("a".matches("\\w"));//返回值:true
System.out.println("aa".matches("\\w"));//返回值:false
System.out.println("_".matches("\\w"));//返回值:true System.out.println("_".matches("\\W"));//返回值:false 说明:\W表示 非单词字符:[^\w]
System.out.println("".matches("\\W"));//返回值:false
System.out.println("a".matches("\\W"));//返回值:false
System.out.println("@".matches("\\W"));//返回值:true 说明:特殊字符都是 //数量词
System.out.println("a".matches("."));//返回值:true 说明:X?表示:X为一次或一次也没有
System.out.println("aa".matches("."));//返回值:false
System.out.println("aa".matches("a."));//返回值:true
System.out.println("aaa".matches("a."));//返回值:false
System.out.println("aaa".matches("a.."));//返回值:true
System.out.println("aa".matches("a?"));//返回值:false System.out.println("a".matches("a*"));//返回值:true 说明:X*表示:X为零次或多次
System.out.println("aa".matches("a*"));//返回值:true
System.out.println("aaaa".matches("a*"));//返回值:true
System.out.println("".matches("a*"));//返回值:true System.out.println("ccccc".matches("c+"));//返回值:true 说明:X+表示:X为一次或多次
System.out.println("c".matches("c+"));//返回值:true
System.out.println("".matches("c+"));//返回值:false
System.out.println(" ".matches("c+"));//返回值:false System.out.println("aa".matches("a{3}"));//返回值:false 说明:X{n}表示:X恰好是n次
System.out.println("aaa".matches("a{3}"));//返回值:true
System.out.println("ccccc".matches("a{3}"));//返回值:false System.out.println("a".matches("a{2,}"));//返回值:false 说明:X{n,}表示:X至少为n次
System.out.println("aa".matches("a{2,}"));//返回值:true
System.out.println("cccccc".matches("c{2,}"));//返回值:true System.out.println("aa".matches("a{3,6}"));//返回值:false 说明:X{n,m}表示:X至少为n次,但是不超过m次
System.out.println("aaa".matches("a{3,6}"));//返回值:true
System.out.println("aaaaaa".matches("a{3,6}"));//返回值:true
System.out.println("aaaaaaaaa".matches("a{3,6}"));//返回值:false //字符类 (范围)
System.out.println("a".matches("[abc]"));//返回值:true 说明:前面的字符"?"要在[abc]中; 是a或b或c
System.out.println("b".matches("[abc]"));//返回值:true
System.out.println("c".matches("[abc]"));//返回值:true
System.out.println("ab".matches("[abc]"));//返回值:false
System.out.println("d".matches("[abc]"));//返回值:false
结合上面的数量词
System.out.println("abc".matches("[abc]{3}"));//返回值:true 说明:{3,}表示:正好出现三次
System.out.println("abc".matches("[abc]{3,}"));//返回值:true 说明:{3,}表示:可以出现三次或三次以上
System.out.println("abc".matches("[abc]+"));//返回值:true 说明:+表示:一次或多次 System.out.println("".matches("[^abc]"));//返回值:true 说明:[^abc]表示:任何字符,除了 a、b或c;即:除了括号中指定的字符
System.out.println("a".matches("[^abc]"));//返回值:false
System.out.println("ab".matches("[^abc]"));//返回值:false
System.out.println("abc".matches("[^abc]"));//返回值:false System.out.println("c".matches("[a-zA-Z]"));//返回值:true 说明:[a-zA-Z]表示:a到z或A到Z,两头的字母包括在内(范围)
System.out.println("aC".matches("[a-zA-Z]"));//返回值:false
System.out.println("aC".matches("[a-zA-Z]{2,}"));//返回值:true
System.out.println("#aC51".matches("[a-zA-Z#5\\d]{2,}"));//返回值:true
System.out.println("#aC58".matches("[a-zA-Z#5\\d]{2,}"));//返回值:true System.out.println("p".matches("[a-d[m-p]]"));//返回值:true 说明:[a-d[m-p]]表示: a到d或m到p:[a-dm-p](并集)
System.out.println("c".matches("[a-d[m-p]]"));//返回值:true
System.out.println("o".matches("[a-d[m-p]]"));//返回值:true
System.out.println("k".matches("[a-d[m-p]]"));//返回值:false System.out.println("a".matches("[a-z&&[def]]"));//返回值:false 说明:[a-z&&[def]]表示:d、e或f(交集)
System.out.println("y".matches("[a-z&&[def]]"));//返回值:false
System.out.println("d".matches("[a-z&&[def]]"));//返回值:true
System.out.println("f".matches("[a-z&&[def]]"));//返回值:true System.out.println("b".matches("[a-z&&[^bc]]"));//返回值:false 说明:[a-z&&[^bc]]表示:a到z,除了b和c:[ad-z](减去)
System.out.println("g".matches("[a-z&&[^bc]]"));//返回值:true
System.out.println("w".matches("[a-z&&[^bc]]"));//返回值:true System.out.println("c".matches("[a-z&&[^m-p]]"));//返回值:true 说明:[a-z&&[^m-p]]表示:a到z,而非m到p:[a-lq-z](减去)
System.out.println("n".matches("[a-z&&[^m-p]]"));//返回值:false
System.out.println("p".matches("[a-z&&[^m-p]]"));//返回值:false
}
}

3、正则表达式  附录:

构造 匹配
 
字符
x 字符 x
\\ 反斜线字符
\0n 带有八进制值 0 的字符 n (0 <= n <= 7)
\0nn 带有八进制值 0 的字符 nn (0 <= n <= 7)
\0mnn 带有八进制值 0 的字符 mnn(0 <= m <= 3、0 <= n <= 7)
\xhh 带有十六进制值 0x 的字符 hh
\uhhhh 带有十六进制值 0x 的字符 hhhh
\t 制表符 ('\u0009')
\n 新行(换行)符 ('\u000A')
\r 回车符 ('\u000D')
\f 换页符 ('\u000C')
\a 报警 (bell) 符 ('\u0007')
\e 转义符 ('\u001B')
\cx 对应于 x 的控制符
 
字符类
[abc] abc(简单类)
[^abc] 任何字符,除了 abc(否定)
[a-zA-Z] azAZ,两头的字母包括在内(范围)
[a-d[m-p]] admp[a-dm-p](并集)
[a-z&&[def]] def(交集)
[a-z&&[^bc]] az,除了 bc[ad-z](减去)
[a-z&&[^m-p]] az,而非 mp[a-lq-z](减去)
 
预定义字符类
. 任何字符(与行结束符可能匹配也可能不匹配)
\d 数字:[0-9]
\D 非数字: [^0-9]
\s 空白字符:[ \t\n\x0B\f\r]
\S 非空白字符:[^\s]
\w 单词字符:[a-zA-Z_0-9]
\W 非单词字符:[^\w]
 
POSIX 字符类(仅 US-ASCII)
\p{Lower} 小写字母字符:[a-z]
\p{Upper} 大写字母字符:[A-Z]
\p{ASCII} 所有 ASCII:[\x00-\x7F]
\p{Alpha} 字母字符:[\p{Lower}\p{Upper}]
\p{Digit} 十进制数字:[0-9]
\p{Alnum} 字母数字字符:[\p{Alpha}\p{Digit}]
\p{Punct} 标点符号:!"#$%&'()*+,-./:;<=>?@[\]^_`{|}~
\p{Graph} 可见字符:[\p{Alnum}\p{Punct}]
\p{Print} 可打印字符:[\p{Graph}\x20]
\p{Blank} 空格或制表符:[ \t]
\p{Cntrl} 控制字符:[\x00-\x1F\x7F]
\p{XDigit} 十六进制数字:[0-9a-fA-F]
\p{Space} 空白字符:[ \t\n\x0B\f\r]
 
java.lang.Character 类(简单的 java 字符类型
\p{javaLowerCase} 等效于 java.lang.Character.isLowerCase()
\p{javaUpperCase} 等效于 java.lang.Character.isUpperCase()
\p{javaWhitespace} 等效于 java.lang.Character.isWhitespace()
\p{javaMirrored} 等效于 java.lang.Character.isMirrored()
 
Unicode 块和类别的类
\p{InGreek} Greek 块(简单)中的字符
\p{Lu} 大写字母(简单类别
\p{Sc} 货币符号
\P{InGreek} 所有字符,Greek 块中的除外(否定)
[\p{L}&&[^\p{Lu}]]  所有字母,大写字母除外(减去)
 
边界匹配器
^ 行的开头
$ 行的结尾
\b 单词边界
\B 非单词边界
\A 输入的开头
\G 上一个匹配的结尾
\Z 输入的结尾,仅用于最后的结束符(如果有的话)
\z 输入的结尾
 
Greedy 数量词
X? X,一次或一次也没有
X* X,零次或多次
X+ X,一次或多次
X{n} X,恰好 n
X{n,} X,至少 n
X{n,m} X,至少 n 次,但是不超过 m
 
Reluctant 数量词
X?? X,一次或一次也没有
X*? X,零次或多次
X+? X,一次或多次
X{n}? X,恰好 n
X{n,}? X,至少 n
X{n,m}? X,至少 n 次,但是不超过 m
 
Possessive 数量词
X?+ X,一次或一次也没有
X*+ X,零次或多次
X++ X,一次或多次
X{n}+ X,恰好 n
X{n,}+ X,至少 n
X{n,m}+ X,至少 n 次,但是不超过 m
 
Logical 运算符
XY X 后跟 Y
X|Y XY
(X) X,作为捕获组
 
Back 引用
\n 任何匹配的 nth 捕获组
 
引用
\ Nothing,但是引用以下字符
\Q Nothing,但是引用所有字符,直到 \E
\E Nothing,但是结束从 \Q 开始的引用
 
特殊构造(非捕获)
(?:X) X,作为非捕获组
(?idmsux-idmsux)  Nothing,但是将匹配标志i d m s u x on - off
(?idmsux-idmsux:X)   X,作为带有给定标志 i d m s u x on - off
(?=X) X,通过零宽度的正 lookahead
(?!X) X,通过零宽度的负 lookahead
(?<=X) X,通过零宽度的正 lookbehind
(?<!X) X,通过零宽度的负 lookbehind
(?>X) X,作为独立的非捕获组

原创作者:DSHORE

作者主页:http://www.cnblogs.com/dshore123/

原文出自:https://www.cnblogs.com/dshore123/p/9132070.html

欢迎转载,转载务必说明出处。(如果本文对您有帮助,可以点击一下右下角的 推荐,或评论,谢谢!

java基础38 正则表达式的更多相关文章

  1. 黑马程序员:Java基础总结----正则表达式

    黑马程序员:Java基础总结 正则表达式   ASP.Net+Android+IO开发 . .Net培训 .期待与您交流! 正则表达式 import  java.util.regex.*; 符合一定规 ...

  2. Java基础七-正则表达式

    Java基础七-正则表达式 一.定义: 特定的符号的组合 二.作用: 用于操作字符串数据 三.优缺点 简化代码,但是阅读性差 四.引入 4.1 问题 判断一个号码是否是QQ号? 不是零开头 6-15位 ...

  3. java基础篇---正则表达式

    正则表达式在许多语言,例如Perl.PHP.Python.JavaScript和JScript,都支持用正则表达式处理文本,一些文本编辑器用正则表达式实现高级“搜索-替换”功能. 正则表达式是一种可以 ...

  4. 黑马程序员——【Java基础】——正则表达式

    ---------- android培训.java培训.期待与您交流! ---------- 一.概述 1. 概念:符合一定规则的表达式. 2. 作用:用于专门操作字符串. 3. 特点:用一些特定的符 ...

  5. 黑马程序员——JAVA基础之正则表达式,网络爬虫

    ------Java培训.Android培训.iOS培训..Net培训.期待与您交流! ------- 正则表达式: 概念:用于操作字符串的符合一定规则的表达式 特点:用于一些特定的符号来表示一些代码 ...

  6. Java基础(63):正则表达式的运用

    Java 正则表达式 正则表达式定义了字符串的模式. 正则表达式可以用来搜索.编辑或处理文本. 正则表达式并不仅限于某一种语言,但是在每种语言中有细微的差别. Java正则表达式和Perl的是最为相似 ...

  7. Java基础巩固--正则表达式

    本篇文章是学习尚学堂的关于正则表达式的视频教程时,所做的笔记.供广大编程爱好者学习之用,也留给日后自己复习使用! 1.为什么要有正则表达式? 正则表达式可以方便的对数据进行匹配,可以进行更加复杂的字符 ...

  8. 【Java基础】正则表达式

    目录 正则表达式 什么正则表达式 普通字符 预定义字符 特殊字符 数量限定字符 定位字符 选择符和分组 反向引用 预搜索 运算符的优先级 常用正则 附录 正则表达式 本文的大部分内容转载自正则表达式从 ...

  9. Java基础教程——正则表达式

    正则表达式·Regular Expression 正则表达式就是一个用于匹配字符串的模板,正则表达式并不仅限于某一种语言,但是在每种语言中有细微的差别. 主要用到的对象: java.util.rege ...

随机推荐

  1. 前端学习 -- 内联框架iframe

    内联框架iframe 可以向一个页面中引入其他的外部页面 内联框架中的内容不会被搜索引擎所检索,所以开发中尽量不要使用内联框架 <iframe></iframe> 属性: sr ...

  2. Struts2的配置文件中, <package>的作用,<action><result>重名?

    问:Struts2的配置文件中, <package>的作用是什么? 答:防止action重名啊,例如前台和后台,总会有很多地方起名重复的! 问:可是访问的时候,不也是访问action吗,能 ...

  3. 闲:测试memcpy和std::copy vector之间拷贝

    预测:底层C函数肯定比stl算法快 结果:少量数据底层快,大数据以上则stl对vector的处理可能更好 C/C++: #include <iostream> #include <v ...

  4. js基础之DOM中document对象的常用属性方法

    -----引入 每个载入浏览器的 HTML 文档都会成为 Document 对象. Document 对象使我们可以从脚本中对 HTML 页面中的所有元素进行访问. 属性 1  document.an ...

  5. go语言从零学起(二)--list循环删除元素(转载)

    本篇系转载 在使用go的container/list的package时,你可能会无意间踩一个小坑,那就是list的循环删除元素. list删除元素,直观写下来的代码如下: package main i ...

  6. 【转载】C#, VB.NET如何将Excel转换为PDF

    在日常工作中,我们经常需要把Excel文档转换为PDF文档.你是否在苦恼如何以C#, VB.NET编程的方式将Excel文档转换为PDF文档呢?你是否查阅了许多资料,运用了大量的代码,但转换后的效果依 ...

  7. Maven学习一:使用Myeclipse创建Maven项目

    使用Myeclipse2014创建Maven项目有如下几种方式: 1.创建Maven Java项目 1.1 选择新建Maven项目 1.2.选择创建简单项目 1.3.填写项目信息 1.4.创建成功后项 ...

  8. nandflash,norflash,sdram,emmc,rom,ram等各种存储器识别

    老是被nandflash,norflash,sdram,emmc,rom,ram搞混,所以在这里总结一下,也为了更好的分清他们之间的关系,以至于别人问的时候不至于说不清. 我们不谈这些名次的由来,只说 ...

  9. 51 nod 1105 第K大的数

    1105 第K大的数 基准时间限制:1 秒 空间限制:131072 KB 分值: 40 难度:4级算法题  收藏  关注 数组A和数组B,里面都有n个整数.数组C共有n^2个整数,分别是A[0] * ...

  10. spring-boot添加自定义拦截器

    spring-boot中的WebMvcConfigurerAdapter类提供了很多自定义操作的方法,先贴出来大家看看 package org.springframework.web.servlet. ...