Vim中查替换及正则表达式的使⽤详解
前⾔
正则表达式是⽂本处理领域中的⼀个强⼤的⼯具,它可以让⽂本处理的能⼒呈指数级的提升,如果⼀款⽂本编辑器不⽀持正则表达式,那么它就算不上是⼀个现代化的编辑器,这绝⾮虚⾔。
下⾯这篇⽂章主要跟⼤家介绍了关于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]
匹配⼗六进制数字,等同于[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”可以有下列写法
:%s/abc\(.*\)xyz/xyz\1abc/g
:%s/\(abc\)\(.*\)\(xyz\)/\3\2\1/g
总结
以上就是这篇⽂章的全部内容了,希望本⽂的内容对⼤家的学习或者⼯作能带来⼀定的帮助,如果有疑问⼤家可以留⾔交流,谢谢⼤家对的⽀持。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论