vim下令大全(好用)

合集下载
相关主题
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 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也同样会删除整个文件,

相关文档
最新文档