一、查找
1、查找命令
/pattern<Enter> :向下查找pattern匹配字符串
?pattern<Enter> :向上查找匹配字符串
在使用了查找命令之后,使用如下两个快捷键查找:
n:按照同一方向继续查找
N:按照反方向查找
pattern是需要匹配的字符串,eg:
/client_sn<Enter> #查找client_sn
/ client_sn <Enter> #查找client_sn单词
除此之外,pattern还可以使用一些通配符,例如(/ ^ $ * .)
二、替换
1、:[range]s/pattern/string/[c,e,g,i]
range指的是范围,1,7指从第一行到第七行,1,$指从第一行至最后一行,也就是整篇文章,也可以使用%代表,%是目前编辑的文章,#是前一次编辑的文章
pattern 就是要被替换掉的字符串,可以用regexp所取代
string 将pattern由string所取代
c confirm 每次替换前会询问
e 不显示error
g globe不询问整行替换
i ignore 不分大小写
I Ignore 大小写敏感
2、基本替换
:s/blue/green/ #替换当前行的第一个blue为green
:s/blue/green/g #替换当前行所有的blue为green
:n,$s/blue/green #替换第n行到最后一行中每一行的第一个blue为green
:n,$s/blue/green/g #替换第n行到最后一行中每一行的所有的blue为green
3、删除文本中的^M
缘由:对于换行,windows下用回车换行来表示,Linux是回车(0A)来表示,这样,将windows上文件拷贝到unix上的时候,总会有个^M,请使用命令过滤unix下windows的换行
使用命令:cat filename 1|tr -d "^V^M" > newfile
使用命令:sed -e "s/^V^M//" filename >outputfilename
在以上两种方法中,^V和^M指的是Ctrl+V和Ctrl+M 必须进行手工输入,而不是进行粘贴
在vi中处理:首先使用vi打开文件,然后按照ESC键,输入命令:
:%s/^V^M//
:%s/^M$//g
如果上述方法无用,则使用
tr -d "/r" <src > dest
tr -d "/015" dest
strings A>B