欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

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

程序员文章站 2022-03-24 16:49:18
...
vim使用技巧——快速编辑篇

转载:http://blog.csdn.net/deutschester/article/details/6935415

与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”,等等。如要多次重复整个字符串,那么该字符串必须被组成一个项。组成一项的方法就是在它前面加 ““,后面加“”。因此这个命令:

       /ab*

匹配: “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”。

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

       /foo∥bar\+

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

  再举个例子:

       /endif∥while∥for

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

相关标签: vim