整理常用的正则表达式

写算法或者工作中,经常需要用到正则表达式,一般情况下,都是上网搜索,由于偶尔遇到需要自己解决的情况,因此做一些正则表达式的学习及积累。

基础篇

1、常用元字符
\s 表示可以匹配任何空白字符串

\d 表示任意任意数字

\w 表示字母、数字、下划线

. 匹配除 "n" 之外的任何单个字符。要匹配包括 'n' 在内的任何字符,请使用像"(.|n)"的模式

2、常用语法
+ 加号代表前面的符号出现一次(只包含原本加号前面的那个字符)或者多次。比如:runoo+b,可以匹配runoob, runoooob

* 星号代表前面的符号可以不出现,或者出现1次或者多次。比如:runoo*b,可以匹配runob, runoob, runooooob

? 问号代表前面的字符最多只能出现一次。比如colou?r可以匹配:color,colour

$ 匹配输入字符串的结尾位置

() 标记一个子表达式的开始和结束位置。子表达式可以获取供以后使用。1表示重复 正则第一个圆括号内匹配到的内容,2表示重复正则第二个圆括号内匹配到的内容

 比如有以下正则:
([a-z])([a-z])\2\1
则可以匹配字符串abba
第一个圆括号内的正则匹配字符a,则在字符串最后\1这个位置必须是字符a,第二个括号匹配字符b,在倒数第二个位置\2必须是字符b
如果有嵌套的圆括号,顺序是按左括号的次序计算的


常用的正则表达式

1、字符串每个字符都是大写:
^[A-Z]+$

2、在字符串中寻找xyxy的子序列,x、y及xy、xy可以不连续:
.*(.).*(.).*\1.*\2.*

3、字符串存在连续相同的字符:
.*(.)\1.*

4、待补充...

补充

1、什么是正则表达式的贪婪与非贪婪匹配

如:String str="abcaxc";
Patter p="ab*c";
(1)贪婪匹配:正则表达式一般趋向于最大长度匹配,也就是所谓的贪婪匹配。如上面使用模式p匹配字符串str,结果就是匹配到:abcaxc(ab*c)。
(2)非贪婪匹配:就是匹配到结果就好,就少的匹配字符。如上面使用模式p匹配字符串str,结果就是匹配到:abc(ab*c)。

2.编程中如何区分两种模式

默认是贪婪模式;在量词后面直接加上一个问号?就是非贪婪模式。
量词:{m,n}:m到n个
*:任意多个
+:一个到多个
?:0或一个
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值