|
前言
正则表达式是文本处理领域中的一个强大的工具,它可以让文本处理的能力呈指数级的提升,如果一款文本编辑器不支持正则表达式,那么它就算不上是一个现代化的编辑器,这绝非虚言。
下面这篇文章主要跟大家介绍了关于Vim查找替换及正则表达式使用的相关内容,分享出来供大家参考学习,下面来一起看看吧。
简单替换表达式
:[range]s/from/to/[flags]
range:搜索范围,如果没有指定范围,则作用于但前行。
-
:1,10s/from/to/ 表示在第1到第10行(包含第1,第10行)之间搜索替换;
-
:10s/from/to/ 表示只在第10行搜索替换;
-
:%s/from/to/ 表示在所有行中搜索替换;
-
1,$s/from/to/ 同上。
flags 有如下四个选项:
-
c confirm,每次替换前询问;
-
e error, 不显示错误;
-
g globle,不询问,整行替换。如果不加g选项,则只替换每行的第一个匹配到的字符串;
-
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 |
匹配<TAB>字符 |
|
\s |
匹配空白字符,等同于[\t] |
|
\S |
匹配非空白字符,等同于[^\t] |
一些普通字符需转意
|
元字符 |
说明 |
|
\* |
匹配* 字符 |
|
. |
匹配. 字符 |
|
\/ |
匹配 / 字符 |
|
\ |
匹配 \ 字符 |
|
\[ |
匹配 [ 字符 |
|
\] |
匹配 ] 字符 |
表示数量的元字符
|
元字符 |
说明 |
|
* |
匹配0-任意个 |
|
\+ |
匹配1-任意个 |
|
\? |
匹配0-1个 |
|
\{n,m} |
匹配n-m个 |
|
\{n} |
匹配n个 |
|
\{n,} |
匹配n-任意个 |
|
\{,m} |
匹配0-m个 |
表示位置的元字符
|
元字符 |
说明 |
|
$ |
匹配行尾 |
|
^ |
匹配行首 |
|
\< |
匹配单词词首 |
|
\> |
匹配单词词尾 |
2、替换变量
在正则式中以\(和\)括起来的正则表达式,在后面使用的时候可以用\1、\2等变量来访问\(和\)中的内容。
例子
-
删除行尾空格::%s/\s+$//g
-
删除行首多余空格:%s/^\s*// 或者 %s/^ *//
-
删除沒有內容的空行:%s/^$// 或者 g/^$/d
-
删除包含有空格组成的空行:%s/^\s*$// 或者 g/^\s*$/d
-
删除以空格或TAB开头到结尾的空行:%s/^[ |\t]*$// 或者 g/^[ |\t]*$/d
-
把文中的所有字符串“abc……xyz”替换为“xyz……abc”可以有下列写法
?
|
1
2
|
:%s/abc\(.*\)xyz/xyz\1abc/g
:%s/\(abc\)\(.*\)\(xyz\)/\3\2\1/g
|
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。
原文链接:http://tanqisen.github.io/blog/2013/01/13/vim-search-replace-regex/ |