首页技术正则表达式匹配 正则表达式编辑器

正则表达式匹配 正则表达式编辑器

编程之家2026-06-30788次浏览

大家好,今天小编来为大家解答以下的问题,关于正则表达式匹配,正则表达式编辑器这个很多人还不知道,现在让我们一起来看看吧!

正则表达式匹配 正则表达式编辑器

正则表达式怎样匹配任意字符

在正则中,匹配任意字符,其实写法网上有很多,但因为各种软件或程序写法不支持等原因导致的问题,大家可以多研究。

今天在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,本文到此结束,希望对大家有所帮助。

指数函数和幂函数 x是幂函数还是指数函数index函数py?index什么意思