一、查找
查找命令
/pattern :向下查找pattern匹配字符串
?pattern:向上查找pattern匹配字符串
使用了查找命令之后,使用如下两个键快速查找:
n:按照同一方向继续查找
N:按照反方向查找
字符串匹配
pattern是需要匹配的字符串
1: /abc #查找abc
除此之外,pattern还可以使用一些特殊字符,包括(/、^、$、*、.),其中前三个这两个是vi与vim通用的,“/”为转义字符。
1: /^abc #查找以abc开始的行
2: /abc$ #查找以abc结束的行
3: //^abc #查找^abc字符串
二、替换
基本替换
1: ?/vivian/sky/ #替换当前行第一个 vivian 为 sky
2: ?/vivian/sky/g #替换当前行所有 vivian 为 sky
3: :n,KaTeX parse error: Expected 'EOF', got '#' at position 19: …ivian/sky/ #̲替换第 n 行开始到最后一行中…s/vivian/sky/g #替换第 n 行开始到最后一行中每一行所有 vivian 为 sky
(n 为数字,若 n 为 .,表示从当前行开始到最后一行)
5: :%s/vivian/sky/ #(等同于:1,
s
/
v
i
v
i
a
n
/
s
k
y
/
:
g
/
v
i
v
i
a
n
/
s
/
/
s
k
y
/
)
替
换
每
一
行
的
第
一
个
v
i
v
i
a
n
为
s
k
y
1
<
e
m
>
6
<
/
e
m
>
:
:
s/vivian/sky/ :g/vivian/s//sky/) 替换每一行的第一个 vivian 为 sky 1 <em>6</em>: :%s/vivian/sky/g #(等同于:1,
s/vivian/sky/:g/vivian/s//sky/)替换每一行的第一个vivian为sky1<em>6</em>::s/vivian/sky/g :g/vivian/s//sky/g)替换每一行的所有 vivian 为 sky
可以使用 #或+ 作为分隔符,此时中间出现的 / 不会作为分隔符
1: ?#vivian/#sky/# 替换当前行第一个 vivian/ 为 sky/
2: :%s+/oradata/apras/+/user01/apras1+ (使用+ 来 替换 / ): /oradata/apras/替换成/user01/apras1/
例如:
1: ?/str1/str2/ #用字符串 str2 替换行中首次出现的字符串 str1
2: ?/str1/str2/g #用字符串 str2 替换行中所有出现的字符串 str1
3: :.,$ s/str1/str2/g #用字符串 str2 替换正文当前行到末尾所有出现的字符串 str1
4: :1,$ s/str1/str2/g #用字符串 str2 替换正文中所有出现的字符串 str1
5: :g/str1/s//str2/g #功能同上@TOC