星期六, 六月 20, 2020

VIM学习笔记 正则表达式-实例(Regex-Examples)

匹配空格

♦ 删除所有行首的空格:

:%s/^□□*\(.*\)/\1/

其中,使用^□□*查找行首的一个或多个空格;而\(.*\)将行中的其它内容捕获为组;在替换部分使用\1来恢复捕获组。

♦ 删除所有行尾的空格:

:%s/\(.*\)□□*$/\1/

其中,使用□□*$查找行尾的一个或多个空格;而\(.*\)将行中的其它内容捕获为组;在替换部分使用\1来恢复捕获组。

♦ 将多个空格替换为一个空格:

:%s/□□*/□/g

其中,第一个□代表一个实际的空格,而□*则会匹配零个或多个空格。

♦ 将冒号或句点之后的多个空格,替换为一个空格:

:%s/\([:.]\)□□*/\1□/g

其中,方括号内的的特殊字符(比如.)并不需要转义。

请在实际使用以上命令时,将其中“□”的替换为空格“ ”。

匹配换行

♦ 如果想要查找的内容之中包含换行符,那么可以使用"\n"通配符。执行以下命令,将匹配以"the"结尾的行,和以"word"开头的下一行:

/the\nword

♦ 如果希望同时匹配包含换行,以及不包含换行(但包含一个空格)的"the word",那么可以使用"\_s"匹配空格或换行:

/the\_sword

♦ 如果希望同时匹配包含多个空格以及换行的"the word",那么可以使用"+"通配符来匹配一次或多次:

/the\_s\+word

Regex_example_the_word

关于删除换行和空行,请参阅换行(Line Feed)章节。

匹配单复数

♦ 将单数单词,替换为复数:

:%s/^Note[□:s]*/Notes:□/g

其中,"Note[□:s]"将匹配"Note□","Notes", 和"Note:";而星号则会匹配零个后缀,即"Note"。

Regex-Examples-Singular

匹配包围的字符串

♦ 匹配引号包围的字符串(包含换行):

"\_[^"]*"

♦ 匹配特定单词包围的字符串(包含换行):

\(we\).*\1

其中,"\(we\)"将指定单词捕获为组,然后使用"\1"反向引用捕获组,以定义字符串的边界。

关于捕获组的详细介绍,请参阅捕获组(Groups)章节。

匹配章节编号

♦ 删除下图中黄色高亮区域,即行头以点分隔的章节号:

:%s/^[1-9][0-9]*\.[1-9][0-9.]*□//

Regex_example_remove_section_headings

其中,模式末尾的"[0-9.]*"可以继续匹配更多层级的章节号。

匹配序列号

♦ 匹配最少3个字符,最多16个字符,由字母和数字组成的用户名:

^[a-zA-Z0-9_-]{3,16}$

♦ 查找类似“1MGU103”的序列号。即由1个数字,3个大写字符和3个数字组成的字符串。可以使用以下几种不同的模式:

[0-9][A-Z]{3}[0-9]{3}

\d\u{3}\d{3}

\d\u\u\u\d\d\d

[[:digit:]][[:upper:]]{3}[[:digit:]]{3}

其中:

  • "[0-9]","\d","[:digit:]",均可匹配数字;
  • "[A-Z]","\u","[:upper:]",均可匹配大写字母;
  • "{3}",用于精确匹配3次。

Regex_example_serial_number

请注意,以上表达式均采用Very Magic模式。

匹配IP地址

♦ 匹配IPv4网络地址。即从"0.0.0.0"到"999.999.999.999"范围内的,以点分割的四段数字。

/\v([0-9]{1,3}[\.]){3}[0-9]{1,3}

但是以上命令,并不会判断数字串是否是一个有效的IP地址。比如"256.60.124.136"也会被匹配。但有效的IP地址中,每段数字均应为"0-255"。

♦ 匹配有效的IP地址。

/\v(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)

Regex_example_ipv4

以上表达式分为四段重复的捕获组,每组数字的范围如下图所示:

Regex_example_ipv4_group

Ver: 2.0 | YYQ<上一篇 | 目录 下一篇>

没有评论:

发表评论