• vim 使用技巧


    vim使用技巧——快速编辑篇

    与vim设置相关的常用基本命令:

    显示行号  :set number 或者 :set nu

    隐藏行号  :set nonumber 或者 :set nonu

    自动缩进 :set autoindent 或者 :set ai

    不自动缩进  :set noautoindent 或者 :set noai

    显示Tab及行尾字符  :set  list

    隐藏Tab及行尾字符  :set nolist

    设置Tab宽度为4个字符  :set tabstop=4

    查看当前设置  :set all 

    定义当前键盘命令  :map keys new_seq

    1、插入

    a        //在光标当前所在字符位置的后面输入文本数据。

    A       // 在光标当前所在行的行尾(也即最后一个字符位置)后面输入文本数据。

    i         //在光标当前所在字符位置的前面输入文本数据。

    I        //在光标当前所在行的行首(也即在第一个非空白的起始字符)前面输入文本数据。

    o       //在光标当前所在行下面的行首位置输入文本数据。

    O       //在光标当前所在行上面的行首位置输入文本数据。

    :ab usa United States of American       //当在文件里插入usa,然后回车,就直接变成了United States of American

    2、快速复制粘贴/剪切粘贴

    0)基本方法:

    y$     //从当前位置复制到行尾
    yy     //复制当前行
    nyy   //或nY,复制当前行以下n行(包括当前行在内)

    nyw  //复制光标之后n个单词
    p       //粘贴在光标以下

    P       //粘贴在光标以上

    dd和ndd也可以认为是“剪切”。

    1)法一:

    在命令模式下(使用set nu显示出行数,则处理起来较为方便):

    :n,m co k     //复制n到m行,粘贴到k行处(从下一行开始)
    :n,m m k      //剪切n到m行,粘贴到k行处(从下一行开始)
    :n,m d          //删除n到m行

    注意的是,m必须大于n,而且m、n、k都在正文行号之内。比如说,如果文件有10行,而你的操作中出现了11,就会出现错误。m可以用特殊符号$,代表到结尾处。


    2)法二
         如果要处理的文本行数比较多,那么可以采用标号的方法。具体如下:

    光标移到起始行,输入ma
    光标移到结束行,输入mb
    光标移到粘贴行,输入mc

    然后 :'a,'b co 'c,就实现了复制粘贴;如果把co改为m,就实现了剪切粘贴。

    3、删除

    nx               //删除光标当前所在位置的字符,或删除从光标当前位置开始(之后)的n个字符

    nX              //删除光标当前所在位置的前一个字符,或删除光标当前所在位置之前的n个字符

    dd              // 删除当前行
    ndd            //删除当前行以下n行(包括当前行在内)
    d l               //删除当前字符(与x命令功能相同)                                       
    d 0             //删除到某一行的开始位置 
    d ^             //删除到某一行的第一个字符位置(不包括空格或TA B字符)              

    d w             //删除到某个单词的结尾位置                                               
    d 3 w          //删除到第三个单词的结尾位置                                         
    d b             //删除到某个单词的开始位置                                               
    d W            //删除到某个以空格作为分隔符的单词的结尾位置                             
    d B             //删除到某个以空格作为分隔符的单词的开始位置                             
    d 7 B          //删除到前面7个以空格作为分隔符的单词的开始位置                     
    d)             //删除到某个语句的结尾位置                                                 
    d 4)          //删除到第四个语句的结尾位置                                           
    d(             //删除到某个语句的开始位置                                                 
    d }              //删除到某个段落的结尾位置                                               
    d {              //删除到某个段落的开始位置                                               
    d 7 {           //删除到当前段落起始位置之前的第7个段落位置                         
    d d             //删除当前行                                                             
    d/t e x t      //注:d与 '/' 间无空格。删除从文本中出现“ t e x t”中所指定字样的位置,一直向前直到下一个该字样所出现的位置(但不包括该字样)之间的内容                                               
    d f c            //删除从文本中出现字符 'c' 的 位置,一直向前直到下一个该字符所出现的位置(包括该字符)之间的内容                                                             
    d t c            //删除当前行直到下一个字符 'c' 所出现位置之间的内容(不包括该字符)                 
    D                //删除到某一行的结尾                                                         
    d $             //删除到某一行的结尾(定价于上命令)                                                     
    5 d d          //删除从当前行所开始的5行内容                                       
    d L              //删除直到屏幕上最后一行的内容                                           
    d H             //删除直到屏幕上第一行的内容                                             
    d G             //删除直到工作缓存区结尾(即整个文件的结尾)的内容                                           
    d 1 G          //删除直到工作缓存区开始(即整个文件的开始)的内容

    :line#1, line#2 d                      //删除从指定的行号line#1到line#2之间的所有文本行

    4、修改命令操作                                                                   
    c l             //更改当前字符                                                           
    c w           //修改到某个单词的结尾位置                                               
    c 3 w        //修改到第三个单词的结尾位置                                         
    c b           //修改到某个单词的开始位置                                               
    c W          //修改到某个以空格作为分隔符的单词的结尾位置                             
    c B           //修改到某个以空格作为分隔符的单词的开始位置                             
    c 7 B        //修改到前面7个以空格作为分隔符的单词的开始位置                     
    c 0           //修改到某行的结尾位置                                                   
    c)          //修改到某个语句的结尾位置                                                 
    c 4)       //修改到第四个语句的结尾位置                                           
    c(          //修改到某个语句的开始位置                                                 
    c }           //修改到某个段落的结尾位置                                               
    c {           //修改到某个段落的开始位置                                               
    c 7 {        //修改到当前段落起始位置之前的第7个段落位置                         
    c tc         //修改当前行直到下一个字符c所出现位置之间的内容                       
    C            //修改到某一行的结尾                                                         
    c c          //修改当前行

    ncc         //修改从当前行开始的n行文本,以Esc键结束                                                            
    5 c c       //修改从当前行所开始的5行内容                             

    [n]cc                                     //替换当前行,或从当前行开始的n行文本,以Esc键结束。

    [n]s         //替换光标当前所在位置的单个字符,或从光标当前位置开始的n个字符,以Esc键结束。

    S             //替换当前行,以Esc键结束。

    r                                                  //替换光标当前所在位置的单个字符。

    r<Enter>                                //断行。也可使用“a”或“i”命令加Enter及Esc键实现。

    R             //从光标当前所在的字符位置开始,替换随后的所有字符,直至按下Esc键

    xp            //交换字符位置。交换光标当前所在位置开始字符位置。

    ddp         //上下两行调换

    :g/^/m0/      //把文件内容反转

    ~             //转换光标当前所在位置字符的大小写。

    J              //上下两行合并

    .              //重复上一次修改(点符号)     

    5、替换命令操作                                                              
    s 将当前字符替换为一个或多个字符                                             
    S 将当前行替换为一个或多个字符                                               
    5 s 将从当前字符开始的5个字符替换为一个或多个字符                        

    通用替换方法 :行1,行2 s/字符串1/字符串2/g。

    其中“行1,行2”指定方法例:
    第5行到第30行  : 5, 30
    当前行到第30行 : ., 30
    第5行到第末尾行 : 5, $
    第5行到含有end的行 : 5, /end/
    所有行 : %


    vi替换使用规则:                                                             
    :g/s1/s/s2/s3/g                                                 
    第一个g表示对每一个包括s1的行都进行替换,第二个g表示对每一行包括s1的行所有的s2都用s3替换;

    s表示替换,s2是要被替换的字符串 ,他可以和s1相同(如果相同的话用//代替),s3是替换字符串 

       补充:查找与替换

    1,简单替换表达式

    替换命令可以在全文中用一个单词替换另一个单词:

    :%s/four/4/g


    “%” 范围前缀表示在所有行中执行替换。最后的 “g” 标记表示替换行中的所有匹配点。如果仅仅对当前行进行操作,那么只要去掉%即可

      如果你有一个象 “thirtyfour” 这样的单词,上面的命令会出错。这种情况下,这个单词会被替换成”thirty4″。要解决这个问题,用 “<” 来指定匹配单词开头:

           :%s/<four/4/g

    显然,这样在处理 “fourty” 的时候还是会出错。用 “>” 来解决这个问题:

           :%s/<four>/4/g

    如果你在编码,你可能只想替换注释中的 “four”,而保留代码中的。由于这很难指定,可以在替换命令中加一个 “c” 标记,这样,Vim 会在每次替换前提示你:

           :%s/<four>/4/gc

    2,删除多余的空格

    要删除这些每行后面多余的空格,可以执行如下命令:

           :%s/s+$//

    命令前面指明范围是 “%”,所以这会作用于整个文件。”substitute” 命令的匹配模式是

    “s+$”。这表示行末($)前的一个或者多个(+)空格(s)。替换命令的 “to” 部分是空的:”//”。这样就会删除那些匹配的空白字符。

    3,匹配重复性模式

    星号项 “*” 规定在它前面的项可以重复任意次。因此:

           /a*

    匹配 “a”,”aa”,”aaa”,等等。但也匹配 “” (空字串),因为零次也包含在内。星号 “*” 仅仅应用于那个紧邻在它前面的项。因此 “ab*” 匹配 “a”,”ab”,”abb”,”abbb”,等等。如要多次重复整个字符串,那么该字符串必须被组成一个项。组成一项的方法就是在它前面加 ““,后面加“”。因此这个命令:

           /abab*

    匹配: “ab”,”abab”,”ababab”,等等。而且也匹配 “”。

    要避免匹配空字串,使用 “+”。这表示前面一项可以被匹配一次或多次。

           /ab+

    匹配 “ab”,”abb”,”abbb”,等等。它不匹配 后面没有跟随 “b” 的 “a”。

    要匹配一个可选项,用 “=”。 例如:

           /folders=

    匹配 “folder” 和 “folders”。

    4,指定重复次数

    要匹配某一项的特定次数重复,使用 “{n,m}” 这样的形式。其中 “n” 和 “m” 都是数字。在它前面的那个项将被重复 “n” 到 “m” 次 (|inclusive| 包含 “n” 和 “m”)。例如:

           /ab{3,5}

    匹配 “abbb”,”abbbb” 以及 “abbbbb”。

      当 “n” 省略时,被默认为零。当 “m” 省略时,被默认为无限大。当 “,m” 省略时,就表示重复正好 “n” 次。例如:

           模式          匹配次数

           {,4}           0,1,2,3 或 4

           {3,}           3,4,5,等等

           {0,1}          0 或 1,同 =

           {0,}           0 或 更多,同 *

           {1,}           1 或 更多,同 +

           {3}            3

    5,多选一匹配

    在一个查找模式中,”或” 运算符是 “|”。例如:

           /foo|bar

    这个命令匹配了 “foo” 或 “bar”。更多的抉择可以连在后面:

           /one|two|three

    匹配 “one”,”two” 或 “three”。

      如要匹配其多次重复,那么整个抉择结构须置于 “”和“” 之间:

           /foobarfoo‖bar+

    这个命令匹配 “foo”,”foobar”,”foofoo”,”barfoobar”,等等。

      再举个例子:

           /endifwhileforif‖while‖for

    这个命令匹配 “endif”,”endwhile” 和 “endfor”。

  • 相关阅读:
    二分插入排序
    LEETCODE 返回两个正序数组的 中位数
    4的幂 算法
    leetcode 两个单链表两数相加
    KMP(The Knuth-Morris-Pratt Algorithm)
    Java Case Interview one
    AWK SED命令 简单入门
    Problem Fix List(always update)
    mysql存储过程快速上手
    java while和switch-case循环
  • 原文地址:https://www.cnblogs.com/2567xl/p/11438938.html
Copyright © 2020-2023  润新知