1、查找
查找命令
/pattern:向下查找匹配的字符
?pattern:向上查找匹配的字符
其中pattern是需要匹配的字符串,例如:
/cd #全文查找cd
/ cd <Enter> #查找<space>cd<space>的字符串(注意空格)
pattern还可以使用正则表达式,“/”为转义字符。
/^cd #查找以cd开始的行
/cd$ #查找以cd结束的行
//^cd<Enter> #查找^cd的字符串
二、替换
基本替换
:s/sun/moon/ #替换当前行第一个sun为moon
:s/sun/moon/g #替换当前行所有sun为moon
:n,$s/sun/moon/ #替换第 n 行开始到最后一行中每一行的第一个sun为moon
:n,$s/sun/moon/g #替换第 n 行开始到最后一行中每一行所有sun为moon
(n为数字,如果n为 . ,表示从当前行开始到最后一行)
:%s/sun/moon/ #(等同于:g/sun/s//moon/)替换每一行的第一个sun为moon
:%s/sun/moon/g #(等同于:g/sun/s//moon/g)替换每一行中所有sun为moon
如果替换字段包含/,可以使用#或+作为分隔符
:s#sun/#moon/# 替换当前行第一个sun/为moon/
:%s+/usr/local/+/var/tmp/+ (使用+替换/):/usr/local/替换成/var/tmp/
删除文本中的^M
windows下的文件如果拷贝到类UNIX系统上,文件结尾总是会有“^M”出现,为了解决这种问题,可以使用以下方法:
使用命令:cat file | tr -d “^V^M” > newfile
使用命令:sed -e “s/^V^M//” file > newfile
其中^V和^M指的是Ctrl+V和Ctrl+M。但是你必须要手工进行输入,而不是粘贴。
在vi中处理:首先使用vi打开文件,然后按ESC键,接着输入命令:
:%s/^V^M//
:%s/^M$//g
如果上述方法无用,则解决办法是:
tr -d “/r” < src >dest
tr -d “/″ dest strings A>B
三、简单的vim正则表达式规则
在vim中有四种表达式规则:
magic(/m):除了$.*^之外其他元字符都要加反斜杠
nomagic(/M):除了$^之外其他元字符都要加反斜杠
/v(即 very magic 之意):任何元字符都不用加反斜杠
/V(即 very nomagic 之意):任何元字符都必须加反斜杠
vim默认使用magic设置,这个设置也可以在正则表达式中通过 /m /M /v /V开关临时切换。例如:
//m.* # 查找任意字符串
//M.* # 查找字符串 .* (点号后面跟个星号) //v(a.c){3}$ # 查找行尾的abcaccadc
//m(a.c){3}$ # 查找行尾的(abc){3}
//M(a.c){3}$ # 查找行尾的(a.c){3}
//V(a.c){3}$ # 查找任意位置的(a.c){3}$
推荐使用默认的magic设置,在这种情况下,常用的匹配有:
//<sun #查找以sun开始的字符串
/moon/> #查找以moon结束的字符串 $ #匹配一行的结束
^ #匹配一行的开始
/< #匹配一个单词的开始,例如//<abc<Enter>:查找以abc开始的字符串
/> #匹配一个单词的结束,例如/abc/><Enter>:查找以abc结束的字符串 * #匹配0或多次
/+ #匹配1或多次
/= #匹配0或1次 . #匹配除换行符以外任意字符
/a #匹配一个字符
/d #匹配任一数字
/u #匹配任一大写字母 [] #匹配范围,如t[abcd]s 匹配tas tbs tcs tds
/{} #重复次数,如a/{,} 匹配3~5个a
/( /) #定义重复组,如a/(xy/)b 匹配ab axyb axyxyb axyxyxyb ...
/| #或,如:for/|bar 表示匹配for或者bar /%20c #匹配第20列
/%20l #匹配第20行