Linux系统Vim进阶之搜索与替换

本文发布时间: 2019-Mar-22
行内搜索行内搜索,也就是在当前行内进行搜索和移动,通常都与编辑命令一起使用。fx -- 移动到下一个字符x的位置,光标停留在x字符上面tx -- 移动到下一个字符x的位置,光标停留在x前一个字符上Fx -- 移动到前一个字符x的位置,光标停留在x字符上面Tx -- 移动到前一个字符x的位置,光标停留在x后一个字符上; -- 重复前一个搜索,向着同一方向,即原来向前就向前,原来向后就向后, -- 重复前一个搜索,向着反方向行内搜索通常与编辑一起使用:dfx/dtx -- 删除到下一个字符xyfx/ytx -- 复制到下一个字符x全局搜索搜索,分为二个部分:一个是搜索命令,另一个是模式匹配;搜索命令就是各个编辑器所支持的启动搜索的方式,比如Windows的各种编辑器都是以对话框的形式。模式就是在对话框中输入的要匹配的字串集。本身字串的匹配功能有限,所以就有了专门用于模式匹配的正则表达式,它描述了模式匹配的一些规则,使用这些规则可以让匹配更加的强大和精准,多数编辑器都支持正则表达式,Vim也不例外,先讲一下搜索命令,然后再讲对正则表达式的支持。基本搜索命令/pattern -- 向前搜索pattern,光标停留在第一个匹配的第一个字符上面。向前的意思是向下,或者向着行数增加的方向。Vim会亮显示所有的匹配,并将光标停留在当前位置的下一个匹配的首字符上/ -- 当不提供pattern时,会向前重复搜索上一个pattern,也就是向前重复搜索的意思,光标会跳到下一个匹配上面?pattern -- 与/pattern类似,只不过它是向后搜索,向着行数减少的方向。? -- 与/类似,是不过是向后重复搜索n -- 向着同一方向重复搜索,原来向前就继续向前,原来向后就继续向后(当向前搜索时与/一样,当向后搜索时与?一样)N -- 向着反方向重复搜索,原来向前就向后,原来向后就向前(向前时?一样,向后时/一样)* -- 向前搜索光标所在的单词,只匹配整个单词,单词的定义是一串连续的字母,数字,标点,空白都是单词的分隔符。# -- 向后搜索光标所在的单词,只匹配整个单词/?+上下方向键 -- 像其他的命令提示符一样,方向键可以方便的引用历史搜索记录如,搜索记录为error, grape, that,那么按了/后,再按向上方向键:/that,再向上:/grape,向下:/that,再次按回车就可以搜索了。正则表达式如前提及,模式匹配在搜索当中有重要的作用。正则表达式(Regular Expression)是专门用于描述搜索中的(Pattern)模式的。使用正则表达式来构建pattern可以让搜索更加强大和精准。有关正则表达式的详细内容可以参阅《Mastering Regular Expression》这本书。正则表达式仅是一种规范,但是各种常用的工具和编程语言都对正则表达式有不同程度的支持。正则表达式有二类:一是正常的字符,仅匹配自身,如"that",只能匹配"that";另一类就是具有特殊意义的元字符。不像基本字符,元字符具有特殊的含义,如.(句点)可以匹配任意除换行符外的单个字符。正则表达式就是学习各种元字符的使用。Vim对正则表达式有很好的支持,它的常用元字符有:通用匹配:. -- 匹配任何除换行符外的单个字符\s -- 匹配一个空白符(space或tab)\S -- 一个非空白符^ -- 仅匹配行首,也即必须以模式开头$ -- 仅匹配行尾,也即必须以模式结尾\< -- 匹配词首,单词定义为一连串的字母,标点空白和数字均视为分隔符\> -- 匹配词尾。\<...\> -- 匹配整个单词(前面命令中的*和#就是用这个来只匹配单词)。当然\<和\>不必一起使用,可以分开使用限量符:* -- 前一个字符出现0次或多次,如a*,可以匹配'', 'a', 'aa'或'aaa'等\+ -- 前一个字符出现1次或多次\= -- 前一个字符出现0次或1次\{n,m} -- 前一个字符出现n到m,如a\{3,5},则可以匹配'aaa', 'aaaa'或'aaaaa'\{n} -- 前一个字符出现n次\{n,} -- 前一个字符出现n次到最多次数(32000)\{} -- 0次或多次,与*一致操作符:\| -- 或,如ab\|ba,则匹配'ab'或'ba'其他:[...] -- 字符集,表达一组字符的集合,匹配其中任何一个字符如[abc],则匹配a或b或c。连续的字符可以用-代替如,[a-c]则匹配a或b或c,[0-9]匹配0到9中任何一个数字,[a-zA-Z]匹配任何一个字母。通常与限量符一起使用,如:/[a-z]\{3,6},长度3到6的小写字串,/[0-9]\{2,4}长度2到4的数字。\(...\) -- 组合,把内部看成一个整体并保存起来以便后续引用。本身作用不大,要与其他元字符一起使用才能发挥其功效\n -- 其中n=1~9,对组合的引用,也即引用\(...\)中所匹配的内容如,/\(that\)\1,则匹配thatthat;/\([a-z]\).\1则匹配,aba, aoa, bcb等。全局替换替换也是编辑器中一个必不可少的功能,Vim对于替换也提供了强大的支持。命令格式:[range]s/pattern/replacement/[options]把[range]所指的范围内的pattern替换为replacement详解range -- 可选。如果缺省就指当前行,也就是后面的命令仅对当前行有效指定方式:n,m -- 从第n行到第m行,包括第n行和第m行。其中.代表当前行; $代表最后一行; %表示全局,等同于1,$options -- 可选,缺省时只替换一行中的第一个匹配常用:g -- 把一行中的所有匹配都替换;c -- 替换之前要求确认示例::s/old/new -- 当前行中的第一个old替换为new:s/old/new/g -- 当前行中的所有old替换为new:s/old/new/gc -- 当前行中的所有old替换为new,每一个替换之前要求确认:5,20s/old/new/gc -- 5到20行中的所有old替换为new,每一个替换之前要求确认:.,20s/old/new/g -- 当前行到20行中的所有old替换为new:.,$s/old/new/gc -- 当前行到最后一行中的所有old替换为new:%s/old/new/gc -- 全局替换,文档中所有的old替换为new根据条件替换前面的替换方式是以行的方式指定具体的范围,也可以以另外一种方式指定范围::g/pattern/s/old/new/gc全局查找pattern,对于匹配pattern的行进行后面的替换,这里的pattern和old都可以使用正则表达式,但是replacement是不能使用正则表达式的,对于replacement,它有自己专属的规则。replacement中的规则>\n n = 1~9 -- 引用pattern中的组合\(...\)。最常用的方式就是调换二个词的顺序或者用于重复输入,如::s/\(that\), \(what\)/\2, \1 -- that, that被换成what, that& -- 替换为模式的匹配,也即如果pattern匹配that,那么&就是that咋一听貌似这个没啥用处,如:s/that/&/gc,这与未替换之前是一样的。它也常用于重复输入,如::s/that/&,&,what/gc -- that替换成that, that, what:s/.*/{&}/g -- 把当前行用{}括起来~ -- 替换为上一次替换命令所用的replacement,而pattern不必相同,也多用于重复编辑如::s/their/our/g -- their --> our:s/his/~/g -- his --> our:s/my/~/g -- my --> our\u或\l -- 把接下来下一个字母转成大写或小写如::s/that/\uthat/g -- that --> That; :s/That\lThat/g -- That --> that。这多少显得有些弱智,直接拼大写或小写更方便。这二个多用于变量,如::s/\(what\)/\u\1/g -- what --> What;:s/\(.*\)/\u&/g 行首大写;:s/\([a-zA-Z]\+\)/\u&/g 每个单词都Captalization\U或\L和\e或\E -- 把replacement中的从\U或\L到\e或\E的所有字母都转成大写或小写,如::s/restore/re\Usto\ere/ -- restore --> reSTOre,这也很弱智。还是与变量才更强大::s/restore/\U&/g -- restore --> RESTORE;:s/ResTore/\L&/g -- ResTore --> restore替换中的技巧:s或:&或:~ -- 重复上次替换命令。可以加上选项g,:sg或:&g或:~g,则会对当前行所有匹配进行替换也可以加上范围% :%sg或:%&g或:%~g,则会对全文所有匹配都替换。:s/pattern/replacement与:s/pattern/replacement一样& -- 直接使用命令&与:&和:s和:~是一样的,即重复上一次替换:和方向键,方向键也可以引用历史命令Vim中的搜索和替换博大精深,要想掌握好唯有不断的练习与实践,这些讲的仅是一个开端。


(以上内容不代表本站观点。)
---------------------------------
本网站以及域名有仲裁协议。
本網站以及域名有仲裁協議。

2024-Mar-04 02:11pm
栏目列表