vim 使用技巧

限于喜欢 提交于 2019-11-29 01:57:38

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”。

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!