zoukankan      html  css  js  c++  java
  • Vim进阶技术:搜索和替换

    行内搜索

    行内搜索,也就是在当前行内进行搜索和移动,通常都与编辑命令一起使用。

    • fx -- 移动到下一个字符x的位置,光标停留在x字符上面
    • tx -- 移动到下一个字符x的位置,光标停留在x前一个字符上
    • Fx -- 移动到前一个字符x的位置,光标停留在x字符上面
    • Tx -- 移动到前一个字符x的位置,光标停留在x后一个字符上
    • ; -- 重复前一个搜索,向着同一方向,即原来向前就向前,原来向后就向后
    • , -- 重复前一个搜索,向着反方向

    行内搜索通常与编辑一起使用:

    • dfx/dtx -- 删除到下一个字符x
    • yfx/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=1~9,对组合的引用,也即引用...中所匹配的内容

      如,/that1,则匹配thatthat;/[az].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 = 1~9 -- 引用pattern中的组合...

      最常用的方式就是调换二个词的顺序或者用于重复输入,如:

      • :s/thatwhat/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/ThatlThat/g -- That --> that。这多少显得有些弱智,直接拼大写或小写更方便。

      这二个多用于变量,如:

      • :s/what/u1/g -- what --> What;
      • :s/./u&/g 行首大写;
      • :s/[azAZ]+/u&/g 每个单词都Captalization
    • U或L和e或E -- 把replacement中的从U或L到e或E的所有字母都转成大写或小写,如::s/restore/reUstoere/ -- 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中的搜索和替换博大精深,要想掌握好唯有不断的练习与实践,这些讲的仅是一个开端。

    参考文献:

    《Learning.the.vi.and.Vim 7th edition》Chap 4, chap 6 and chap 10

  • 相关阅读:
    CCF--稀疏向量
    CCF--线性分类器
    腾讯位置服务实现轨迹回放
    3分钟搞定微信小程序类美团用户商家距离计算
    腾讯地图获取全国行政区划检索列表Demo
    vue接入腾讯地图(二)【标注&定位实战】
    vue接入腾讯地图(一)【点击事件】
    微信小程序结合腾讯地图获取用户所在城市信息
    vue使用腾讯位置服务选点组件问题总结
    Linux 内核container_of
  • 原文地址:https://www.cnblogs.com/duhuo/p/4333377.html
Copyright © 2011-2022 走看看