正则表达式小结

常用元字符

代码 说明
. 匹配除换行符以外的任意字符
\w 匹配字母或数字或下划线或汉字
\s 匹配任意的空白符
\d 匹配数字
\b 匹配单词的开始或结束
^ 匹配字符串的开始
$ 匹配字符串的结束

常用限定符

代码/语法 说明
* 重复零次或更多次
+ 重复一次或更多次
? 重复零次或一次
{n} 重复n次
{n,} 重复n次或更多次
{n,m} 重复n到m次

常用反义词

代码/语法 说明
\W 匹配任意不是字母,数字,下划线,汉字的字符
\S 匹配任意不是空白符的字符
\D 匹配任意非数字的字符
\B 匹配不是单词开头或结束的位置
[^x] 匹配除了x以外的任意字符
[^aeiou] 匹配除了aeiou这几个字母以外的任意字符

对其中的 常用限定符做一些解释。

* 重复零次或多次,准确的讲应该是“零次或多次匹配前面的字符或子表达式”。例如,zo* 匹配“z”和“zoo”。* 等效于 {0,}。为什么会匹配"z",因为会匹配去掉前一个字符的子表达式。即“z” ,如果是zmmo*,那么会匹配zmm和zmmo两个表达式,且重复零次到多次。

+ 一次或多次匹配前面的字符或子表达式。例如,“zo+”与“zo”和“zoo”匹配,但与“z”不匹配。+ 等效于 {1,}。

? 零次或一次匹配前面的字符或子表达式。例如,“do(es)?”匹配“do”或“does”中的“do”。? 等效于 {0,1}。

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

还有需要注意的是“\”,将下一字符标记为特殊字符、文本、反向引用或八进制转义符。例如,“n”匹配字符“n”。“\n”匹配换行符。序列“\\”匹配“\”,“\(”匹配“(”。

时间: 2024-12-17 13:29:55

正则表达式小结的相关文章

C#正则表达式小结

C#正则表达式小结    只能输入数字:"^[0-9]*$".只能输入n位的数字:"^\d{n}$".只能输入至少n位的数字:"^\d{n,}$".只能输入m~n位的数字:."^\d{m,n}$"只能输入零和非零开头的数字:"^(0|[1-9][0-9]*)$".只能输入有两位小数的正实数:"^[0-9]+(.[0-9]{2})?$".只能输入有1~3位小数的正实数:"^[0-

[转]FINDSTR正则表达式小结

前言:最近写了一个bat用于快速编译swf至目标目录,想利用FINDSTR命令通过匹配目标目录名称,匹配数量大概600多个,发现匹配耗时比较久,大概花费10余秒,因此还是放弃字符匹配,乖乖拼出全称来定位目录.感觉bat的运行效率是比较低的. 稍加搜索,看到一些帖子也印证了我的想法.bat不适合做太复杂的事.还是分享下FINDSTR命令的用法. 批处理运行效率讨论帖汇总 FINDSTR正则表达式小结 什么是正则表达式?百度 http://baike.baidu.com/view/94238.htm

正则表达式 小结

正则表达式是一种文本模式,经常被用来匹配具有某种规则的文本. 正则表达式可以写得很复杂,内容也可以很高深,但是常用的规则很简单.本文主要小结一下最近用到的正则表达式语法,足以满足平常的小需求了. 首先先了解一下基本单元:特殊字符与元字符.  http://msdn.microsoft.com/zh-cn/library/ae5bf541(v=vs.100).aspx 这篇文章中有详细的参考清单. 特殊字符就是它本身不匹配某种单词,但是它有辅助含义,比如 ^表示当前模式一定要出现在文本的开头,$表

Python正则表达式小结(1)

学习一段python正则表达式了, 对match.search.findall.finditer等函数作一小结  下面以一段网页为例,用python正则表达式作一个范例: strHtml = '''<div> <a href="/user/student/" class="user-t"><img src="/uploads/avatar/2015/06/082e408c-14fc-11e5-a98d-00163e02100b

js正则表达式小结

虽然一直在使用正则表达式,但是一直没有系统的归纳.以下从正则表达是的功能进行相应的介绍.如有不正确的地方,望请纠正. 模式检测功能 模式检测是指要检测的文本是否符合我们预期的模式,主要用于做登录.注册的验证等:如,我们经常在注册时要求账号长度为6-16位等,以下是常用正则表达式 手机号码:/[1-9][0-9]{10}/ 邮箱:/^([a-zA-Z0-9_-])[email protected]([a-zA-Z0-9_-])+((.[a-zA-Z0-9_-]{2,3}){1,2})$/ 身份证:

正则表达式小结(Regular Expressions)

(原创文章,谢绝转载~) 日常开发中,常用正则表达式方便的进行匹配.筛选工作.正则的常用内容有: 一般情况下原则:从左至右,越多越好(贪婪) 字符:转义:\ ,如 \*,\d (数字)等 选择,case1|case2|case3, 注意:对于大部分正则引擎,匹配规则是从左至右优先,因而,string|stringlong  会匹配到 stringlong 的 string 部分: 少数  Text-Directed Engine  的匹配规则则是最长优先,此时 string|stringlong

linux正则表达式与文件格式化处理指令

1.特殊符号: 1)[:alnum:]:字母和数字 2)[:alpha:]:字母 3)[:blank:]:空格和tab键 4)[:cntrl:]:控制键CR,LF,Tab,Del等 5)[:digit:]:数字 6)[:graph:]:除了空格符(空格和tab)外的其他按键 7)[:lower:]:小写字母 8)[:print:]:可打印字符 9)[:punct:]:标点符号 10)[:upper:]:大写字母 11)[:space:]:空白字符,如空格,tab,ctr等 12)[:xdigit

使用正则表达式的格式化与高亮显示json字符串

使用正则表达式的格式化与高亮显示json字符串 json字符串很有用,有时候一些后台接口返回的信息是字符串格式的,可读性很差,这个时候要是有个可以格式化并高亮显示json串的方法那就好多了,下面看看一个正则表达式完成的json字符串的格式化与高亮显示 首先是对输入进行转换,如果是对象则转化为规范的json字符串,不是对象时,先将字符串转化为对象(防止不规范的字符串),然后再次转化为json串.其中json为输入. if (typeof json !== 'string') { json = JS

JavaScript正则表达式知识汇总

Js 正则表达式知识汇总 正则表达式: 1.什么是RegExp?RegExp是正则表达式的缩写.RegExp 对象用于规定在文本中检索的内容. 2.定义RegExp:var +变量名=new RegExp(); 3.RegExp 对象有 3 个方法: 1)test()检索字符串中的指定值,返回值是true或false. var p1=new Reg("e"); document.write(Reg.test("welcome to China!")); 2)exec