vim的正则表达式之元字符

得记忆了,越难记,越难理解的,越能帮助自己开阔思路,愈能解答多年来的疑惑。

简单替换表达式

:[range]s/from/to/[flags]

•range:搜索范围,如果没有指定范围,则作用于但前行。
1.:1,10s/from/to/ 表示在第1到第10行(包含第1,第10行)之间搜索替换;
2.:10s/from/to/ 表示只在第10行搜索替换;
3.:%s/from/to/ 表示在所有行中搜索替换;
4.1,$s/from/to/ 同上。

•flags 有如下四个选项:
1.c confirm,每次替换前询问;
2.e error, 不显示错误;
3.g globle,不询问,整行替换。如果不加g选项,则只替换每行的第一个匹配到的字符串;
4.i ignore,忽略大小写。

这些选项可以合并使用,如cgi表示不区分大小写,整行替换,替换前询问。

正则表达式

1.元字符

•元字符

元字符

说明

. 匹配任意字符
[abc] 匹配方括号中的任意一个字符,可用-表示字符范围。如[a-z0-9]匹配小写字母和数字
[^abc] 匹配除方括号中字符之外的任意字符
\d 匹配阿拉伯数字,等同于[0-9]
\D 匹配阿拉伯数字之外的任意字符,等同于[^0-9]
\x 匹配十六进制数字,等同于[0-9A-Fa-f]
\X 匹配十六进制数字之外的任意字符,等同于[^0-9A-Fa-f]
\l 匹配[a-z]
\L 匹配[^a-z]
\u 匹配[A-Z]
\U 匹配[^A-Z]
\w 匹配单词字母,等同于[0-9A-Za-z_]
\W 匹配单词字母之外的任意字符,等同于[^0-9A-Za-z_]
\t 匹配字符
\s 匹配空白字符,等同于[\t]
\S 匹配非空白字符,等同于[^\t]

•一些普通字符需转意

元字符

说明

\* 匹配* 字符
. 匹配. 字符
\/ 匹配 / 字符
\ 匹配 \ 字符
\[ 匹配 [ 字符
\] 匹配 ] 字符

•表示数量的元字符

元字符

说明

* 匹配0-任意个
\+ 匹配1-任意个
\? 匹配0-1个
\{n,m} 匹配n-m个
\{n} 匹配n个
\{n,} 匹配n-任意个
\{,m} 匹配0-m个

•表示位置的元字符

元字符

说明

$ 匹配行首
^ 匹配行尾
\< 匹配单词词首 \> 匹配单词词尾

2.替换变量

在正则式中以\(和\)括起来的正则表达式,在后面使用的时候可以用\1、\2等变量来访问\(和\)中的内容。

例子
1.删除行尾空格::%s/\s+$//g
2.删除行首多余空格:%s/^\s*// 或者 %s/^ *//
3.删除沒有內容的空行:%s/^$// 或者 g/^$/d
4.删除包含有空格组成的空行:%s/^\s*$// 或者 g/^\s*$/d
5.删除以空格或TAB开头到结尾的空行:%s/^[ |\t]*$// 或者 g/^[ |\t]*$/d

6.把文中的所有字符串“abc……xyz”替换为“xyz……abc”可以有下列写法

发表回复

您的电子邮箱地址不会被公开。