vim下令大全(好用)
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
:%s+/oradata/apras/+/user01/apras1+ (使用+ 来替换/ ):/oradata/apras/替换成/user01/apras1/
* ************************************
1.:s/vivian/sky/ 替换当前行第一个vivian 为sky
:s/vivian/sky/g 替换当前行所有vivian 为sky
2. :n,$s/vivian/sky/ 替换第n 行开始到最后一行中每一行的第一个vivian 为sky
:n,$s/vivian/sky/g 替换第n 行开始到最后一行中每一行所有vivian 为sky
(n 为数字,若n 为 .,表示从当前行开始到最后一行)
3. :%s/vivian/sky/(等同于:g/vivian/s//sky/) 替换每一行的第一个vivian 为sky
:%s/vivian/sky/g(等同于:g/vivian/s//sky/g) 替换每一行中所有vivian 为sky
4. 可以使用# 作为分隔符,此时中间出现的/ 不会作为分隔符
:s#vivian/#sky/# 替换当前行第一个vivian/ 为sky/
5. 删除文本中的^M
问题描述:对于换行,window下用回车换行(0A0D)来表示,linux下是回车(0A)来表示。这样,将window上的文件拷到unix上用时,总会有个^M.请写个用在unix下的过滤windows文件的换行符(0D)的shell或c程序。
· 使用命令:cat filename1 | tr -d “^V^M” > newfile;
· 使用命令:sed -e “s/^V^M//” filename > outputfilename。需要注意的是在
1、2两种方法中,^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
6. 其它
利用:s 命令可以实现字符串的替换。具体的用法包括:
:s/str1/str2/ 用字符串str2 替换行中首次出现的字符串str1
:s/str1/str2/g 用字符串str2 替换行中所有出现的字符串str1
:.,$ s/str1/str2/g 用字符串str2 替换正文当前行到末尾所有出现的字符串str1
:1,$ s/str1/str2/g 用字符串str2 替换正文中所有出现的字符串str1
:g/str1/s//str2/g 功能同上
从上述替换命令可以看到:g 放在命令末尾,表示对搜索字符串的每次出现进行替换;不加g,表示只对搜索
字符串的首次出现进行替换;g 放在命令开头,表示对正文中所有包含搜索字符串的行进行替换操作。
有如下文本
msg "haha"
msg "hhhaaa"
我想让它变成
msg "HEADhahaTAIL"
msg "HEADhhhaaaTAIL"
用什么替换命令?
:%s/haha\|hhhaaa/HEAD&TAIL/
global命令是Vim最强大的命令之一(个人认为是No.1),将其摸透用熟可以事半功倍,
本文总结了版上的一些经典问题,结合自己的使用和理解,试图通过实例详细介绍一下
其用法。示例难度不一,有些并没有多少实用性,为题而生,读者各取所需吧。示例说
明并不非常细致,以免罗唆。每节标题下列出了所涉及的内容在Vim help中的位置,以供查找。文中用词未必标准(我没看过Vim中文帮助),观点也难免有错,请大家指正!
1. global命令形式
:h :g
:h 12.4
:[range]global/{pattern}/{command}
global命令在[range]指定的文本范围内(缺省为整个文件)查找{pattern},然后对匹
配到的行执行命令{command},如果希望对没匹配上的行执行命令,则使用global!或vg lobal命令。
先来看Vim用户手册里的一个经典例子。
【例1】倒序文件行(即unix下的tac命令)
:g/^/m 0
这条命令用行首标记/^/匹配文件的所有行(这是查找的一个常用技巧,如果用/./则是
匹配非空行,不满足本例要求),然后用move命令依次将每行移到第一行(第0行的下一
行),从而实现了倒序功能。
global命令实际上是分成两步执行:首先扫描[range]指定范围内的所有行,给匹配{pa ttern}的行打上标记;然后依次对打有标记的行执行{command}命令,如果被标记的行在对之前匹配行的命令操作中被删除、移动或合并,则其标记自动消失,而不对该行执行{command}命令。标记的概念很重要,以例说明。
【例2】删除偶数行
:g/^/+1 d
这条命令也是匹配所有行,然后隔行删除(其中+1用以定位于当前行的下一行)。为什么是隔行呢?因为在对第一行执行+1 d命令时删除的是第二行,而第二行虽然也被标记了,但已不存在了,因此不会执行删除第三行的命令。
本例也可以用normal命令实现:
:%norm jdd
%指定整个文件,然后依次执行普通模式下的jdd,即下移删除一行。与global命令不同之处在于,%norm是按照行号顺序执行,在第一行时删除了第二行,后面的所有行号都减一,因此在第二行执行jdd时删除的是原来的第四行。也就是说,global命令是通过偶数行标记的消失实现的,而normal命令是通过后续行的自动前移实现的。
【例3】删除奇数行
:g/^/d|m.
光是:g/^/d显然不行,这会删除所有行,我们需要用move命令把偶数行的标记去掉。当然,本例可以很简单的转换成【例2】,在此只是用来强调标记的概念。
本例若想用normal命令实现比较有意思,%norm dd也同样会删除整个文件,