正则表达式匹配 正则表达式编辑器
大家好,今天小编来为大家解答以下的问题,关于正则表达式匹配,正则表达式编辑器这个很多人还不知道,现在让我们一起来看看吧!
正则表达式怎样匹配任意字符
在正则中,匹配任意字符,其实写法网上有很多,但因为各种软件或程序写法不支持等原因导致的问题,大家可以多研究。
今天在Java中想使用正则表达式来获取一段文本中的任意字符。于是很随意得就写出如下匹配规则:
(.*)
结果运行之后才发现,无法获得换行之后的文本。于是查了一下手册,才发现正则表达式中,“.”(点符号)匹配的是除了换行符“\n”以外的所有字符。同时,手册上还有一句话:要匹配包括
'\n'在内的任何字符,请使用像'[.\n]'的模式。于是我将正则表达式的匹配规则修改如下:
([.\n]*),当然,如果是在java程序中直接写到话,需要改为([.\\n]*)
结果再次运行程序,发现什么内容也取不到了。我百思不得其解,又将其修改为如下规则:
([.|\n]*)以及([\n.]*)
结果还是不行,什么内容都取不到。看来点符号和换行符卯上劲了~
然后上网一查,虽然没有查出上述规则到底是什么地方出问题了,但是查出了一个解决办法,经过一试,果然可以匹配包括换行符在内的任意字符,以下为正确的正则表达式匹配规则:
([\s\S]*)
同时,也可以用“([\d\D]*)”、“([\w\W]*)”来表示。
在文本文件里,
这个表达式可以匹配所有的英文
/[-~]/
这个表达式可以匹配所有的非英文(比如中文)
/[^-~]/
/是VI里用的.
你在editplus或程序里不需要/
正则表达式位置匹配攻略【转】
正则表达式是匹配模式,要么匹配字符,要么匹配位置。请记住这句话。
然而大部分人学习正则时,对于匹配位置的重视程度没有那么高。
本文讲讲正则匹配位置的总总。
内容包括:
1.什么是位置?
2.如何匹配位置?
3.位置的特性
4.几个应用实例分析
位置是相邻字符之间的位置。比如,下图中箭头所指的地方:
在ES5中,共有6个锚字符:
2.1 ^和$
^(脱字符)匹配开头,在多行匹配中匹配行开头。
$(美元符号)匹配结尾,在多行匹配中匹配行结尾。
比如我们把字符串的开头和结尾用"#"替换(位置可以替换成字符的!):
多行匹配模式时,二者是行的概念,这个需要我们的注意:
2.2 \b和\B
\b是单词边界,具体就是\w和\W之间的位置,也包括\w和^之间的位置,也包括\w和$之间的位置。
比如一个文件名是"[JS] Lesson_01.mp4"中的\b,如下:
为什么是这样呢?这需要仔细看看。
首先,我们知道,\w是字符组[0-9a-zA-Z_]的简写形式,即\w是字母数字或者下划线的中任何一个字符。而\W是排除字符组[^0-9a-zA-Z_]的简写形式,即\W是\w以外的任何一个字符。
此时我们可以看看"[#JS#]#Lesson_01#.#mp4#"中的每一个"#",是怎么来的。
第一个"#",两边是"["与"J",是\W和\w之间的位置。
第二个"#",两边是"S"与"]",也就是\w和\W之间的位置。
第三个"#",两边是空格与"L",也就是\W和\w之间的位置。
第四个"#",两边是"1"与".",也就是\w和\W之间的位置。
第五个"#",两边是"."与"m",也就是\W和\w之间的位置。
第六个"#",其对应的位置是结尾,但其前面的字符"4"是\w,即\w和$之间的位置。
知道了\b的概念后,那么\B也就相对好理解了。
\B就是\b的反面的意思,非单词边界。例如在字符串中所有位置中,扣掉\b,剩下的都是\B的。
具体说来就是\w与\w、\W与\W、^与\W,\W与$之间的位置。
比如上面的例子,把所有\B替换成"#":
2.3(?=p)和(?!p)
(?=p),其中p是一个子模式,即p前面的位置。
比如(?=l),表示'l'字符前面的位置,例如:
而(?!p)就是(?=p)的反面意思,比如:
二者的学名分别是positive lookahead和negative lookahead。
中文翻译分别是正向先行断言和负向先行断言。
ES6中,还支持positive lookbehind和negative lookbehind。
具体是(?<=p)和(?<!p)。
也有书上把这四个东西,翻译成环视,即看看左边或看看右边。
但一般书上,没有很好强调这四者是个位置。
比如(?=p),一般都理解成:要求接下来的字符与p匹配,但不能包括p的那些字符。
而在本人看来(?=p)就与^一样好理解,就是p前面的那个位置。
对于位置的理解,我们可以理解成空字符""。
比如"hello"字符串等价于如下的形式:
也等价于:
因此,把/ hello$/写成/ ^hello$$$/,是没有任何问题的:
甚至可以写成更复杂的:
也就是说字符之间的位置,可以写成多个。
把位置理解空字符,是对位置非常有效的理解方式。
4.1不匹配任何东西的正则
让你写个正则不匹配任何东西
easy,/.^/
因为此正则要求只有一个字符,但该字符后面是开头。
4.2数字的千位分隔符表示法
比如把"12345678",变成"12,345,678"。
可见是需要把相应的位置替换成","。
思路是什么呢?
4.2.1弄出最后一个逗号
使用(?=\d{3}$)就可以做到:
4.2.2弄出所有的逗号
因为逗号出现的位置,要求后面3个数字一组,也就是\d{3}至少出现一次。
此时可以使用量词+:
4.2.3匹配其余案例
写完正则后,要多验证几个案例,此时我们会发现问题:
因为上面的正则,仅仅表示把从结尾向前数,一但是3的倍数,就把其前面的位置替换成逗号。因此才会出现这个问题。
怎么解决呢?我们要求匹配的到这个位置不能是开头。
我们知道匹配开头可以使用^,但要求这个位置不是开头怎么办?
easy,(?!^),你想到了吗?测试如下:
4.2.4支持其他形式
如果要把"12345678 123456789"替换成"12,345,678 123,456,789"。
此时我们需要修改正则,把里面的开头^和结尾$,替换成\b:
其中(?!\b)怎么理解呢?
要求当前是一个位置,但不是\b前面的位置,其实(?!\b)说的就是\B。
因此最终正则变成了:/\B(?=(\d{3})+\b)/g
4.3验证密码问题
密码长度6-12位,由数字、小写字符和大写字母组成,但必须至少包括2种字符。
此题,如果写成多个正则来判断,比较容易。但要写成一个正则就比较困难。
那么,我们就来挑战一下。看看我们对位置的理解是否深刻。
4.3.1简化
不考虑“但必须至少包括2种字符”这一条件。我们可以容易写出:
4.3.2判断是否包含有某一种字符
假设,要求的必须包含数字,怎么办?此时我们可以使用(?=.*[0-9])来做。
因此正则变成:
4.3.3同时包含具体两种字符
比如同时包含数字和小写字母,可以用(?=. [0-9])(?=. [a-z])来做。
因此正则变成:
4.3.4解答
我们可以把原题变成下列几种情况之一:
1.同时包含数字和小写字母
2.同时包含数字和大写字母
3.同时包含小写字母和大写字母
4.同时包含数字、小写字母和大写字母
以上的4种情况是或的关系(实际上,可以不用第4条)。
最终答案是:
4.3.5解惑
上面的正则看起来比较复杂,只要理解了第二步,其余就全部理解了。
/(?=.*[0-9])^[0-9A-Za-z]{6,12}$/
对于这个正则,我们只需要弄明白(?=.*[0-9])^即可。
分开来看就是(?=.*[0-9])和^。
表示开头前面还有个位置(当然也是开头,即同一个位置,想想之前的空字符类比)。
(?=. [0-9])表示该位置后面的字符匹配. [0-9],即,有任何多个任意字符,后面再跟个数字。
翻译成大白话,就是接下来的字符,必须包含个数字。
4.3.6另外一种解法
“至少包含两种字符”的意思就是说,不能全部都是数字,也不能全部都是小写字母,也不能全部都是大写字母。
那么要求“不能全部都是数字”,怎么做呢?(?!p)出马!
对应的正则是:
三种“都不能”呢?
最终答案是:
位置匹配相关的案例,挺多的,不一而足。
感谢你看到这里,本文也要结束了。
如果有更好的例子,也可以帮我补充补充。
最后,我们该想到,陆游诗人对前端做的最大贡献是:
纸上得来终觉浅,绝知此事要躬行。
本文完。
系列总目录传送门
如何在正则表达式中使用条件匹配
在正则表达式中,条件匹配允许根据特定条件选择不同的匹配模式,其核心逻辑类似于编程中的 if-else。以下是详细说明:
一、基本语法结构条件匹配的两种主要形式:
简单条件:(?(condition)true-pattern)若 condition成立,则匹配 true-pattern。完整条件:(?(condition)true-pattern|false-pattern)若 condition成立,匹配 true-pattern;否则匹配 false-pattern。条件类型:
捕获组是否存在:如(1)检查第一个分组是否被捕获。零宽断言:如(?=...)(正向预查)或(?<=...)(反向预查)。
二、核心用法示例1.基础示例:根据分组存在与否切换模式(abc)?(?(1)def|xyz)逻辑:若(abc)被捕获(分组1存在),则后续必须匹配 def;否则匹配 xyz。匹配结果:输入 abcdef→匹配成功(abc+ def)。
输入 xyz→匹配成功(直接匹配 xyz)。
2.应用场景:匹配带引号或不带引号的字符串处理HTML属性值时,需兼容带单/双引号或无引号的情况:
(["'])?([^"']+)(?(1)1|(?!s))分解:(["'])?:捕获可选的引号(分组1)。
([^"']+):匹配非引号内容。
(?(1)1|(?!s)):若存在引号(分组1存在),则必须匹配相同闭合引号(1)。
若无引号,则后续不能为空格((?!s)),避免误匹配其他属性。
示例匹配:
value="test"→匹配"test"(引号闭合)。value=test→匹配 test(无引号且后无空格)。3.使用命名组提升可读性通过命名组(如?<quote>)简化复杂表达式:
(?<quote>["'])?(w+)(?(quote)1|.)逻辑:(?<quote>["'])?:命名分组 quote捕获可选引号。
(w+):匹配单词字符。
(?(quote)1|.):若存在 quote,则匹配相同闭合引号(1)。
否则匹配点号(.),可能用于占位或终止符。
三、注意事项与兼容性引擎支持:
支持的语言/工具:Perl、PHP(PCRE)、Python的 regex模块(非标准库 re)、.NET Framework。
不支持的语言:JavaScript原生正则、Java标准库等。
性能与可读性:
条件匹配可能降低正则性能,尤其在复杂场景下。
过度使用会降低代码可维护性,建议仅在必要时使用。
替代方案:
若环境不支持条件匹配,可通过多次匹配或字符串预处理实现类似逻辑。
四、总结核心语法:(?(condition)true-pattern|false-pattern),通过检查分组或断言切换匹配模式。典型场景:处理可选引号、条件性闭合标签等结构化文本。兼容性:优先确认目标环境是否支持(如PCRE兼容引擎)。掌握条件匹配可显著提升正则的灵活性,但需权衡复杂度与实际需求。
OK,本文到此结束,希望对大家有所帮助。