替换-Substitute
格式:
:<范围>/查找/替换/次数
范围
| %s | 整个文件 |
| '<,'>s | 选择模式下选取的内 |
| 1,$s | 从第1行到文件尾 |
| .,$s | 当前行至文件尾 |
| 5,15s | 5-15行 |
| .,.+8s | 当前行至后8行 |
特定字符做为替换范围。
比如,将SQL语句从FROM至;部分中的=替换为<>:
范围:FROM至; 查找:= 替换:<> 范围:所有
:/FROM/,/;/s/=/<>/g
以下还未整理完
简单替换表达式
:[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表示不区分大小写,整行替换,替换前询问。
特殊字符
与正则相同
特殊规则
可以不使用/作为分隔符,可以使用#和+
使用
| [ range ]s | / | Pattern | / | String | / | Type | Cmd | Effect |
|---|---|---|---|---|---|---|---|---|
| / | a | / | b | / | :s/a/b/g | 当前行第一个a换b | ||
%s | / | a | / | b | / | g | :%s/a/b/g | 全局alla换b |
'<,'>s | / | a | / | b | / | :'<,'>s/a/b/ | 选区每行首个a换b | |
1,$s | / | a | / | b | / | g | :1,$s/a/b/g | 1行-尾行所有a换成b |
.,$s | / | a | / | b | / | g | :.,$s/a/b/g | 当前行-尾行所有a换成b |
5,15s | / | a | / | b | / | c | :5,15s/a/b/c | 第1-15行所有a换成b,每个要确认 |
.,.+8s | / | a | / | b | / | g | :.,.+8s/a/b/g | 当前行-后8行所有a换成b |
%s | / | vim$ | / | b | / | g | :%s/vim$/b/g | 全局所有正则匹配换成b |
%s | # | 1/2s | # | 2/3b | # | i | :%s#1/2s#2/3b#i | 全局所有1/2s换成2/3b,无视大小写 |
/FROM/,/;/s | / | = | / | <> | / | g | :/FROM/,/;/s/=/<>/g | FROM到;区间所有=换成<> |
VIM查找与正则
\c大小写不敏感
\C大小写敏感/foo\C`对大小写敏感查找
元字符
元字符
| 元字符 | 说明 |
|---|---|
| . | 匹配任意字符 |
| [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-任意个 |
| {,m} | 匹配0-m个 |
表示位置的元字符
| 元字符 | 说明 |
|---|---|
| $ | 匹配行尾 |
| ^ | 匹配行首 |
| < | 匹配单词词首 |
| > | 匹配单词词尾 |
替换变量
在正则式中以\(和\)括起来的正则表达式,在后面使用的时候可以用\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
评论