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”。
如要匹配其多次重复,那么整个抉择结构须置于 “”和“”和“” 之间:
/foo∥barfoo‖bar\+
这个命令匹配 “foo”,”foobar”,”foofoo”,”barfoobar”,等等。
再举个例子:
/endif∥while∥forif‖while‖for
这个命令匹配 “endif”,”endwhile” 和 “endfor”。