可视化正则表达式教程,web开发模式

30 阅读8分钟

正则表达式与我们期望的单词'cool'匹配时,它的操作方式不是单词级别而是字符级别,这是我们需要理清的一个点。

注意点:正则表达式在字符级别工作,而不是单词级别。

这意味着正则表达式'cool'也将与以下句子匹配。

基本构建基块


现在我们已经理解了关键点,接下来我们了解一下如何使用正则表达式匹配简单字符。

特定字符

我们可以在正则表达式中指定字符,它将匹配文本中的所有实例。

例如,下面给出的正则表达式将匹配文本中所有'a'实例:

'a'

也可以使用从09的任何数字,来匹配数字。

'3'

请注意,默认情况下,正则表达式区分大小写,因此以下正则表达式不匹配任何内容。

'A'

空格字符

我们可以使用特殊的转义序列来检测特殊字符,例如空格和换行符。

除了上述常见的,我们还有:

  • \r 回车

  • \f 换页

  • \e 可执行模式

特殊字符

正则表达式提供了一堆内置的特殊字符,这些字符可以一次匹配一组字符,这些字符以反斜杠\开头。

模式:\d

它匹配09之间的数字。

注意,匹配项是一位数。 因此,我们在下面有4个不同的匹配项,而不是单个数字18.04

模式:\s

它匹配任何空格字符(空格、制表符或换行符)。

模式:\w

它匹配任何小写字母(az),大写字母(AZ),数字(09)和下划线。

模式:.

它匹配除换行符(\n)以外的任何字符。

let str = 'line 1\nline2'

str.match(/./g)

// 结果:["l", "i", "n", "e", " ", "1", "l", "i", "n", "e", "2"]

模式:否定

如果我我们使用上述模式的大写形式,则表示他们否定的一面。

例如,如果\d匹配从09的任何数字,则\D将匹配09之外的任何数字。

字符集

字符集模式以[ 开始,以]结束,并匹配括号括起来的字符。例如,以下模式匹配任何字符'a', 'e', 'i', 'o''u'

我们也可以使用以下模式来代替\d的功能。

除了指定所有数字,我们还可以使用连字符合-仅需指定开始和结束数字。 因此,我们可以用[0-9]代替[0123456789]

例如,[2-4]可用于匹配24(即234)之间的任何数字。

我们可以在括号内使用上面讲的特殊字符。 例如,匹配09之间的任何数字或空白字符:

下面,列出了一些通用模式及其含义。

锚点

正则表达式还具有特殊的处理程序,以使模式仅在字符串的开头或结尾时才匹配。

我们只能使用 ^ 字符来匹配以指定开始的模式。例如

同样,我们可以在字符后使用$字符 ,表示以指定字符结尾。 例如:

转义元字符

考虑一种情况,我们要完全匹配单词 "Mr. Stark"

如果我们想用这样的格式 Mr. Stark 来匹配,那么它会产生意想不到的效果。因为我们知道.在正则表达式中有特殊的意义。

因此,如果我们想是精确匹配字符本身,则需要对特殊的元字符(如.$等)进行转义。

下面是元字符列表,如果直接使用它们,记住要对它们进行转义。

^ $ . * + ? { } [ ] \ | ( )

重复类


现在我们可以对任何字符进行模式匹配,接着,我们来接触较复杂一点的模式。

笨的方式来匹配重复字符

仅使用到目前为止所学的知识,幼稚的方法就是重复这种模式。 例如,我们可以通过重复字符级模式来匹配两位数字。

\d\d

量词

正则表达式提供特殊的量词来指定其前面字符的不同重复类型。

固定重复

我们可以使用{...}量词来指定模式应重复的次数。

例如,可以将先前用于匹配两位数字的模式修改为:

我们还可以使用相同的量词指定重复范围。 例如,要匹配2位数或者4位数字,可以使用以下模式:

当应用于句子时,它将同时匹配4位数字和2位数字。

注意 最小和最大计数之间不应该有任何空格,例如,\d{2, 4}不工作。

灵活的量词

正则表达式还提供了量词*+? 使用它可以指定字符的灵活重复。

? 字符表示匹配 0 次或者 一次

例如,假设我们想匹配单词“sound”和“sounds”,其中“s”是可选的。我们可以使用?量词。

+ 字符表示匹配 一 次或者多次

例如,我们可以使用正则 \d+找到任意长度的数字。

* 字符表示匹配 0 次或者多次

在Python中的用法


Python在标准库中提供了一个名为"re"的模块来使用正则表达式。

对原始字符串的需求

要在Python中指定正则表达式,我们在r之前创建原始字符串

pattern = r'\d'

为了理解为什么我们在前面加上r,我们尝试打印不带**r**的表达式\t

pattern = '\t'

print(pattern)

可以看到,当我们不使用原始字符串时,字符串\t在Python中被视为制表符的转义字符。

现在我们把它转换成原始字符串,我们会得到我们指定的任何东西

pattern = r'\t'

print(pattern)

\t

使用 re 模块


文末

如果30岁以前,可以还不知道自己想去做什么的话,那30岁之后,真的觉得时间非常的宝贵,不能再浪费时间在一些碎片化的事情上,比如说看综艺,电视剧。一个人的黄金时间也就二,三十年,不能过得浑浑噩噩。所以花了基本上休息的时间,去不断的完善自己的知识体系,希望可以成为一个领域内的TOP。

同样是干到30岁,普通人写业务代码划水,榜样们深度学习拓宽视野晋升管理。

这也是为什么大家都说30岁是程序员的门槛,很多人迈不过去,其实各行各业都是这样都会有个坎,公司永远都缺的高级人才,只用这样才能在大风大浪过后,依然闪耀不被公司淘汰不被社会淘汰。

269页《前端大厂面试宝典》

包含了腾讯、字节跳动、小米、阿里、滴滴、美团、58、拼多多、360、新浪、搜狐等一线互联网公司面试被问到的题目,涵盖了初中级前端技术点。

前端面试题汇总

JavaScript

开源分享:docs.qq.com/doc/DSmRnRG…