正则表达式

目录

正则表达式:

符号:

边界匹配器

预定义字符类 \

范围  [ ]

数量 { }

子表达式 ()

预查  

常用

应用:


正则表达式:

操作字符串的一种规则,使用了特殊的符号表示

符号:

正则表达式 – 元字符 | 菜鸟教程正则表达式 - 元字符 下表包含了元字符的完整列表以及它们在正则表达式上下文中的行为: 字符 描述 \ 将下一个字符标记为一个特殊字符、或一个原义字符、或一个 向后引用、或一个八进制转义符。例如,'n' 匹配字符 'n'。'\n' 匹配一个换行符。序列 '\\' 匹配 '\' 而 '\(' 则..https://www.runoob.com/regexp/regexp-metachar.html

边界匹配器

  • ^   匹配输入字符串的开始位置。
  • $   匹配输入字符串的结束位置
  • \b         只是代表了单词的开始或结束部分,不匹配任何字符

预定义字符类 \

.        任何字符(与行结束符可能匹配也可能不匹配)

\d      数字:[0-9]

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

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

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

\w     单词字符:[a-zA-Z_0-9]

\W    非单词字符:[^\w]

注意:任何预定义字符没有加上数量词之前只能匹配一个字符

范围  [ ]

范围里 ^ 表示 非 

[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(交集)

注意:没有数量词也只能匹配一个字符

数量 { }

Greedy

X?         X,一次或一次也没有

X*         X,零次或多次

X+        X,一次或多次

X{n}       X,恰好n次

X{n,}        X,至少n次

X{n,m}       X,至少n次,但是不超过m次

子表达式 ()

预查  

用来检查接下来的出现的是不是某个特定的字符集

(?:pattern) 非获取匹配

(?=pattern) 肯定预查 :后面是pattern

(?!pattern) 否定预查:后面不是pattern

(?<=pattern) 反向肯定预查:前面是pattern

(?<!pattern) 反向否定预查:前面不是pattern


常用

正则表达式在线测试 | 菜鸟工具

密码设置6-12位,须包含字母、数字或特殊符号中的2种

^(?![A-Za-z]+$)(?!\\d+$)(?![\\W_]+$)\\S{6,12}$


应用:

匹配 :

matches(String regex)          当且仅当字符串指定的正则表达式匹配返回true

切割: 

split()

为了提高规则复用, 用()进行分组,组号从1开始,可以通过编号来引用组所匹配到的内容。需要对编号数字进行转义:\\1就代表获取1组匹配到的内容。
例:
String[] arr = str.split(" +");     \\根据空格进行切割
String[] arr = str.split("(.)\\1+");     \\根据重叠词进行切割

替换 :

replaceAll(String regex, String replacement)

例:
String[] arr = str.replaceAll("(.)\\1+","$1");    \\把重叠词替换单个词
在replaceAll方法正则的外部引用组的内容要使用" $组号"

查找 :

查找不能使用string直接使用,需要使用对象:
  1. Pattern(正则对象)
  2. Matcher(匹配器对象)
匹配器方法:
  1. find()    通知匹配器去匹配字符串,查找符合规则的字符串。返回true,false
  2. group()    获取符合规则的子串(在使用group方法之前,必须要先用find方法查找,否则报错)
指定为字符串的正则表达式必须先被编译为此类的实例,然后可将得到的正则对象匹配任意的字符串用于创建Matcher对象,执行匹配所设计的所有状态都驻留在匹配器中。典型调用顺序为:
Pattern p = Pattern.compile("正则表达式");   \\字符串的正则编译成Pattern对象
Matcher m = p.matcher("aaaaab");     \\使用正则对象匹配字符串产生一个Matcher对象
boolean b = m.matches();

 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值