:s / SEARCH / REPLACE / g 注:把当前光标所处的行中的SEARCH单词,替换成REPLACE,并把所有SEARCH高亮显示;
: % s / SEARCH / REPLACE 注:把文档中所有SEARCH替换成REPLACE;
:#,# s / SEARCH / REPLACE / g 注:#号表示数字,表示从多少行到多少行,把SEARCH替换成REPLACE;
注:在这之中,g表示全局查找;我们注意到,就是没有替换的地方,也会把SEARCH高亮显示;
举例说明:
比如我们有一篇文档要修改;
我们把光标所在的行,把所有单词the,替换成THE,应该是:
:s / the / THE / g
我们把整篇文档的所有的the都替换成THE,应该是:
: % s / the / THE
我们仅仅是把第1行到第10行中的the,替换成THE,应该是;
: 1 , 10 s / the / THE / g
tags:搜索,正则表达式,常用,VIM
- 去掉所有的行尾空格:“:%s//s/+$//”。“%”表示在整个文件范围内进行替换,“/s”表示空白字符(空格和制表符),“/ +”对前面的字符匹配一次或多次(越多越好),“$”匹配行尾(使用“/$”表示单纯的“$”字符);被替换的内容为空;由于一行最多只需替换一次,不需 要特殊标志。这个还是比较简单的。
- 去掉所有的空白行:“:%s//(/s*/n/)/+//r/”。这回多了“/(”、“/)”、“/ n”、“/r”和“*”。“*”代表对前面的字符(此处为“/s”)匹配零次或多次(越多越好;使用“/*”表示单纯的“*”字符),“/n”代表换行 符,“/r”代表回车符,“/(”和“/)”对表达式进行分组,使其被视作一个不可分割的整体。因此,这个表达式的完整意义是,把连续的换行符(包含换行 符前面可能有的连续空白字符)替换成为一个单个的换行符。唯一很特殊的地方是,在模式中使用的是“/n”,而被替换的内容中却不能使用“/n”,而只能使 用“/r”。原因是历史造成的,详情如果有兴趣的话可以查看“:help NL-used-for-Nul”。
- 去掉所有的“//”注 释:“:%s!/s*//.*!!”。首先可以注意到,这儿分隔符改用了“!”,原因是在模式或字符串部分使用了“/”字符,不换用其他分隔符的话就得在 每次使用“/”字符本身时写成“//”,上面的命令得写成“:%s//s*.*//”,可读性较低。命令本身倒是相当简单,用过正则表达式的人估 计都知道“.”匹配表示除换行符之外的任何字符吧。
- 去掉所有的“/* */”注释:“:%s!/s*//*/_./{-}/*//s*! !g”。这个略有点复杂了,用到了几个不太常用的 Vim 正则表达式特性。“/_.”匹配包含换行在内的所有字符;“/{-}”表示前一个字符可出现零次或多次,但在整个正则表达式可以匹配成功的前提下,匹配的 字符数越少越好;标志“g”表示一行里可以匹配和替换多次。替换的结果是个空格的目的是保证像“int/* space not necessary around comments */main()”这样的表达式在替换之后仍然是合法的。
tags:TAG,VIM
大家一般都知道,在 Vim 的帮助窗口中的关键字上双击鼠标或者键入“Ctrl-]”即可跳转至该关键字相关的帮助主题。不过,“跳转至匹配的关键字”这一功能并不仅仅局限于帮助文 件。只要有合适的 tags 文件(参见“:help tags-file-format”),我们同样可以在源代码中使用这个方便的功能,跳转到与关键字匹配的“标记”处(通常是源代码中某一函数、类型、变 量或宏的定义位置)。
要产生 tags 文件,通常我们使用 Exuberant Ctags [15]。一般的 Linux 发布版中均带有这一工具。Ctags 带有的选项数量极多,此处我们仅简单介绍如何在一个典型的多文件、多层目录的项目中使用其基本功能:我们只需在项目的根目录处键入“ctags -R .”,Ctags 即可自动在文件中查找、识别支持的文件格式、生成 tags 文件。目前 Exuberant Ctags 支持多达 33 种编程语言 [16],包括了 Linux 下常用的 C、C++、Java、Perl、PHP 等。有了 tags 文件,以下的 Vim 命令就可以方便使用了(进一步的信息可参考“:help tags-and-searches”):
- :tag 关键字(跳转到与“关键字”匹配的标记处)
- :tselect [关键字](显示与“关键字”匹配的标记列表,输入数字跳转到指定的标记)
- :tjump [关键字](类似于“:tselect”,但当匹配项只有一个时直接跳转至标记处而不再显示列表)
- :tn(跳转到下一个匹配的标记处)
- :tp(跳转到上一个匹配的标记处)
- Ctrl-](跳转到与光标下的关键字匹配的标记处;除“关键字”直接从光标位置自动获得外,功能与“:tags”相同)
- g](与“Ctrl-]”功能类似,但使用的命令是“:tselect”)
- g Ctrl-](与“Ctrl-]”功能类似,但使用的命令是“:tjump”)
- Ctrl-T(跳转回上次使用以上命令跳转前的位置)
当 我们在项目的根目录下工作时,上面这些命令工作得很好。但如果我们进到多层目录的里层再运行 Vim 打开文件时,这些命令的执行结果通常就变成了错误信息“E433: No tags file”。这是因为缺省 Vim 只在文件所在目录和当前目录下寻找 tags 文件,而我们前面只在项目的根目录下生成了 tags 文件,Vim 无法找到该文件。解决方法有好几种,我认为一般较简单的做法是对每个项目都在 .vimrc 文件中增加一个路径相关设定。假设我们有两个项目,位置分别是 /home/my/proj1 和 /home/my/proj2,那我们可以使用:
|
Vim 选项 tags 用于控制检查的 tags 文件,缺省值为“./tags,tags”,即前面所说的文件所在目录下和当前目录下的 tags 文件。上面两行自动命令告诉 Vim,在打开项目目录下的文件时,tags 选项中的内容要增加项目的 tags 文件的路径。进一步信息可参看“:help 'tags'”。
tags:VIM,小技巧
也许你会觉得这些很有用:
- %(跳转到与之匹配的括号处)
- .(重复上次的修改命令)
- `.(跳转到最近修改过的位置)
- ZQ(无条件退出)
- ZZ(存盘退出)
- ga(显示光标下的字符在当前使用的 encoding 下的内码)
- guw(光标下的单词变为小写)
- gUw(光标下的单词变为大写)
- :TOhtml(根据 Vim 的语法加亮的方式生成 HTML 代码;在图形界面中也可以使用菜单“Syntax—Convert to HTML”达到同样效果)
无聊的时候,还可以试试(呵呵!):
- :help!
- :help 42
- :help holy-grail
参考:
http://www-128.ibm.com/developerworks/cn/linux/l-tip-vim1/#author
end