VIM使用入门(汇集)

Posted lcinx

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了VIM使用入门(汇集)相关的知识,希望对你有一定的参考价值。

转自phpCHINA

在linux下使用VIM进行编程是一件很自然的事情
刚开始时我也对VI超多的指令和完全的放弃鼠标感到不适!
但经过了初期的适应性阶段,我终于放发现,原来放弃了鼠标却也提高了效率!
废话少说,进入正题:
``(TAB上边的点):回到光标跳转前的位置。
dd:删除一行。
5dd:删除光标处以下的五行。
按V键进入可视模式,选择要拷贝的内容,按yy拷贝选中的内容,在需要的地方按p拷贝内容到新光标处或新文件中。
i:进入插入模式。
v:进入可视模式。
Esc:回到基本模式
h,j,k,l:上下左右移动光标
vsp:左右分割窗口。
sp:上下分割窗口。
ctrl+w:在窗口中选择。
:q!:不保存退出。
x:保存退出。
w:只保存不退出。
x:删除一个字符。
u:撤消
CTRL+O:回跳。
CTRL+R:撤消刚才的撤消。
:help:帮助。
zz:退出帮助窗口。
3w :向前移动三个单词。
3b:向后移动三个单词。
CTRL+[:跳到光标单词处。
CTRL+T:跳回。
9k:上移九行。
:e 打开新文件(在多窗口操作中很有用)。
yaw:拷贝一个单词。
CTRL+B:把光标移到当前行的左边首部。
CTRL+E:把光标移到当前行的右边首部。
vim -r doc.txt:恢复文件到修改前。
:/查找单词
H:跳到第一行。
M:跳到中间。
L:跳到最后一行。
CTRL+d,u,f,b:下移半屏,上移半屏,下移一屏,上移一屏。
gg:到文件开始处
G:到文件尾部。
--:找到文件上次修改点。
CTRL+p,n:向上查询一个单词,向下查询一个单词。
zo:打开折叠。l键也可以。
zc:关闭折叠。
zr:全部打开折叠。
zm:全部关闭折叠。
zf:创建折叠。
zR:打开所有折叠(包括嵌套)
zM:关闭所有折叠(包括嵌套)
:!ls,查看目录表。
:`o,找到最后修改的文件。
wq,保存退出。
vim txt1 txt2 txt3 txt4,同时打开多个文件,
以下是同时打开多个文件时(建议用多窗口)
n,下一个文件,
n3,往下第三个文件。
first,第一个文件。
last,最后一个文件 。
:/s#kkk#ccc#g,把文件中的kkk替换为ccc

0. 序言

编程人员花费最长时间的开发工具可能就是编辑器了,一个非常方便、高效的编辑器对开发人员来说是非常有效的。在unix/linux下,甚至windows下,vim都可以说是个非常优秀的编辑器。虽然许多朋友开发过程中都在使用vim,但通常只使用了vim非常有限的功能,没有接触到vim的很多非常符合开发人员需求的功能。下面就从开发人员的角度出发,介绍开发过程经常使用到的功能。读完本文,您会发现vim原来是如此强大的集成开发环境。

 

Vim是基于GPL的开源项目,是对vi的提升版本,而vi是unix环境下最通用的编辑器。不过由于vim的强大的功能,许多最新发布的linux版本中已经把vim作为默认vi编辑器了。如果您的系统中没有安装vim,可以从vim.sourceforge.net上下载合适的版本。闲话少提,下面从基本编辑命令、通用编辑命令、开发常用命令等方面介绍vim。本文以介绍功能为主,使用细节多尝试一下就明白了。以下讨论基于vim 6.2。

在vim中,使用 :new创建新窗口。 

 

1.基本编辑命令

本节简单分类基本的vim编辑命令,只给出简单的功能说明,作为使用vim的命令速查,详细描述请查看vim的在线帮助。Vim下输入:h <命令>即可。下面的命令是在常态模式下(就是任何状态下多按几次ESC键后到达的状态,为了避免概念模糊,这里对这些状态不进行描述)输入的字符序列。

 

命令

含义

命令

含义

移动

h

j

k

l

左下上右(和方向键相同含义)

H

M

L

同一页(屏幕)内的第一行、中间行、

最后一行

ctrl+f

ctrl+b

下一页

上一页

ctrl+d

ctrl+u

下半页

上半页

b

w

e

前一个单词首

后一个单词首

后一个单词尾

0

^

$

行首

行首的非空字符

行尾

 

 

 

 

输入

a

A

当前字符后输入

行尾输入

i

I

当前字符前输入

行前输入

o

O

当前行下插入新行输入

当前行上插入新行输入

:r [filename]

当前行下插入文件[filename]的内容

 

 

 

 

改变

d[范围]

删除范围内的文字,如:dw(删除到词尾)d$(删除到行尾)

c[范围]

改变,删除指定范围后直接进入编辑状态

~[范围]

改变当前字符或者范围内的大小写

J

连接当前行和下一行

r[char]

替换字符,使用随后输入的字符替换当前字符

R

进入替换模式,输入的字符替换文本的文字

y[范围]

拷贝范围内的文字

p

粘贴到当前字符后

x

删除当前字符

.

重复最后一条改变文本内容的命令

 

 

 

 

查找

f[char]

F[char]

行内向后查找字符[char]

行内向前查找字符[char]

t[char]

T[char]

行内向后查找字符[char]前

行内向前查找字符[char]前

/[string]

?[string]

向下查找[string]

向上查找[string]

查找后使用n继续查找,使用N向相反方向继续查找

*

#

向下查找光标当前单词

向上查找光标当前单词

n

N

重复最后一次/ ? 命令

相反方向重复最后一次/ ? 命令

 

 

 

 

 

 

其他

:e filename

关闭当前文件,编辑文件

:w filename

写入文件中

ctrl+g

:g

显示文件信息

:help [cmd]

查看vim的命令cmd的帮助信息

:u

undo一个改变

:red

重做undo的改变

U

undo当前行所有的改变

 

 

 

注:

[范围] 是界定上个动作的范围,vim里面称为motion。上面的改变类命令都属于motion命令,意思是指移动了光标位置。

命令

含义

命令

含义

0

到行第一个字符

^

到行第一个非空字符

$

到行最后一个字符

 

 

[n]k

[n]j

向上几行

向下几行

[n]w

删除n个单词

 

 

 

 

 

上面的分类是个人为便于记忆进行分类,没有特定标准或已有规则。

 

2. 通用命令

 

2.1. 搜索

搜索应该说是开发过程中非常常用的命令。最常见的搜索命令是 /  和 ? ,后面加需搜索的词句或者正则表达式(简单的介绍见下面一小结)。然后使用 n 或者 N 找下一个或者上一个搜索结果。

开发过程中最可能的情况是看到一个词希望能够找到它,这时候 * (向下搜索当前词)和 #(向上搜索当前词)命令就非常方便。如果想搜索包含当前词的词都可以可以使用 g* 或者 g# 命令。

找到变量的定义,可以使用gd(当前词的局部变量定义)和gD(当前词的全局变量定义)命令,这两个命令不一定非常准确,但有时候还是比较有用的。

当前词的宏定义,可以使用 [_ctrl-d 找到当前词第一个出现在#define 后的位置。而 [d 显示当前文件和包含文件中当前词的第一个宏定义, [D 列出所有的宏定义。 ] 开始的命令是从当前位置开始搜索。

在当前文件和包含头文件中进行搜索,搜索宏定义可以使用上面说的命令,函数、变量等的声明、引用的搜索,可以使用 [i (从文件头开始搜索包含当前词的位置)命令, [I 列出所有的行。 ] 开始的命令是从当前位置开始搜索。Vim的命令还是比较有一致性的。跳到出现的位置则使用 [_ctrl-i (从第一行开始),或者 ]_ctrl_i (从当前位置开始)。

多文件的搜索可以通过外部命令 :grep 来实现,缺省情况和使用grep命令非常类似,查找出来的列表,可以使用Quickfix类命令来在列表中循环访问,通过此类命令也可以在多个grep命令列表中进行跳转,此类命令初始为编译出错时设计的,在3.4节介绍相关命令时详细描述。

替换命令格式比较长,但有时候又非常有用,必须理解它每一个细节才能保障灵活使用。命令格式如下:

       :[range]s[ubstitute]/{pattern}/{string}/[][c][e][g][p][r][i][I] [count]

这个命令的含义就是在range的范围内,查找pattern定义的模式替换为string。

Range的定义可以参考:help range,通常可以指定行数,标记,甚至指定一个搜索也可以,例如:

       3,.+1             从3行到当前行的后一行

       ‘t,$-2            从标记t到文章尾后两行

       %                 全部文章,相当于.,$

      .,/{pattern}/   从当前行到下一个匹配pattern的行

pattern和上面介绍的搜索模式一样可以是一个字符串或者是正则表达式。

String通常可以是字符串,其他特殊内容可以参考:help sub-replace-special 。

最后的标记的含义如下:

        保持上个替换命令的标记

       c    每次替换进行确认

       g    对每行所有匹配的模式进行替换,缺省一行只替换一次

       i     忽略大小写

       I     不忽略大小写

 

2.2. 正则表达式

使用正则表达式极大的增强了搜索、替换的描述能力,但这也增加了学习的难度。这里把开发过程中可能使用的标记简单的罗列一下,然后举几个例子,大家应该可以举一反三,大致知道如何使用了。匹配模式的学习可以参考:help pattern 。

命令

含义

命令

含义

ordinary atom

^

\_^

匹配行首,必须在pattern开始

任何地方匹配行首

$

\_$

匹配行尾,必须在pattern最后

任何地方匹配行尾

.

\_.

匹配任意字符,不能在行尾

任意地方匹配字符

<

>

词首

词尾

 

 

 

 

multi items

*

0或多个

+

1或多个

?

0或1个

{n,m}

n到m个,尽量匹配多数个

{-n,m}

n到m个,尽量匹配少数个

 

 

character classes

s

S

空白字符<space> <TAB>

非空白字符

d

D

数字

非数字

x

X

十六进制数字

非十六进制数字

a

A

字母a-zA-Z

w

W

词字符包括字母、数字和下划线

h

H

首字符包括字母和下划线

 

 

 

 

其他

e



<ESC>

<TAB>

<CR>

<BS>

<NewLine>

c

C

忽略大小写

匹配大小写

 

 

 

 

 

这样c语言的标志符就可以使用 <hw* 来匹配;

<caw*5       匹配以ca为词开始中间包含5的任意词;

 

2.3. 多窗口

开发过程中有时候需要打开多个文件或者看一个文件的不同部分,这种情况就是多窗口的功用做在。

打开一个新窗口使用 :split [filename] 命令,加文件名打开的窗口编辑此文件,否则编辑当前文件。

关闭当前窗口使用 :q 即可。

Ctrl-w j 下一个窗口

Ctrl-w k 上一个窗口

ctrl-w = 所有窗口等高、宽

ctrl-w + 增加当前窗口高度

ctrl-w – 减少当前窗口高度

不同的文件在内存中的数据是一个buffer,一个buffer可以有1个或多个window,甚至没有window。在多个文件间跳转(后面介绍)时,通常文件所在buffer仍然在内存。可以使用 :buffers 列出当前内存中所有buffer。

使用:bn (下一个buffer)和 :bp (上一个buffer)在buffer间循环。

 

2.4. 可视模式

图形界面使用太多了,可能觉得使用命令界定范围不直观,可视模式则允许可视的选择一块文本,然后输入相关命令对其进行操作。其使用过程是移动到块开始字符,输入命令进入可视模式;使用各种移动命令移动到块尾;输入相关命令对此块内容进行操作。

v           进入字符选择可视模式

V           进入行选择可视模式

Ctrl-v    进入块选择可视模式

 

2.5. 标记(mark)

对某行做一个标记有时候是非常有用的功能。以后可以方便的移动到此行,在motion中也可以引用这个位置。

设置标记使用 m{a-zA-Z} 设置一个标记,名字是后面跟的字符,一个文件内可以定义a-z共26个标记,文件间可以定义一个A-Z共26个标记。

移动到标记行,使用 ‘[char] 或者 `[char] 命令移动到[char]对应的标记。

 

2.6. 文件恢复

敲半天的东西不能因为断电丢失了。Vim缺省输入200个字符或者空闲4秒就自动保存在.swp文件中。

通常的恢复步骤是,移动到文件所在目录下;使用vim –r [filename] 恢复filename文件,如果编辑的文件没有保存使用 vim –r “” 即可;把恢复的文件另存为另一个文件,使用diff程序(可以使用vimdiff)查看是否正确恢复。如果不记得文件名,使用 vim –r 列出所有交换文件。

 

3. 开发常用命令

3.1. tag

有tag后能够非常方便的在多个源代码文件中进行跳转,这个特性非常方便浏览、阅读代码。

C/C++源程序可以使用 ctags -R *.c *.cpp 产生tag文件,ctag已经包含在最新的vim发布版本中。有了tag文件,就可以方便的跳转了。

使用vim –t [tagname] 启动vim可以直接打开相应的文件,并定位到tagname的位置。在vim里使用命令 :tag [tagname] 可以跳转到tagname的定义,tagname可以使用正则表达式来进行模糊匹配。

使用ctrl-] 可以直接跳动到当前词的定义,如果当前词不是tag,使用右边的第一个tagname。这个跳动过程组成tag堆栈,沿堆栈跳回的命令是 ctrl-t ,沿堆栈上下移动的命令是 :tn (老的项),:tp (新的项)。列出tag堆栈使用 :tags 。

 

3.2. 预览窗口

调用函数时,通常非常需要查看函数的参数,使用tag技术和预览窗口可以方便的实现这个功能。

命令 :ptag [tagname] 在预览窗口显示跳转到tagname定义。当前词作为tagname,可以直接输入 ctrl-w } ,在预览窗口查看当前词的定义。

关闭预览窗口使用 :pclose 命令。

在预览窗口打开一个文件,使用 :pedit [filename] 命令。在当前文件和包含文件中搜索某个词,并显示到预览窗口中,可以使用 :psearch [name]。通常使用这个命令搜索函数原型。

 

3.2. 移动

vim缺省非常好的支持多种缩进方式。调整缩进可以使用 < (向左缩进)或者 >(向右缩进),前面可以加范围,或者后面加motion。

使用 ={motion} 命令对一块文字进行自动缩进。

找到对应的{}、[]、(),有时候比较麻烦,使用 % 命令可以非常方便找到对应的符号,除了上面的几组符号,还可以是 /* */ 或者 #if #ifdef #else #elif #endif 等。

代码块通常是由{}包括的,在各个代码块之间移动是非常方便的。 [{ 移动到光标所在块首, ]} 移动到所在块尾。使用命令 [[ 跳转到最外层的{,]] 跳转到最外层的},最外层通常是C/C++程序的函数边界。第二层的{使用 [m 命令,第二层的}使用 ]m 命令,通常java程序第二层才是函数的边界。

在文件内或者文件间跳转,有时候需要返回上次光标所在位置。可以使用ctrl-o 命令跳转到以前的位置,ctrl-i 命令跳转到新的位置。使用命令 :jumps 列出所有跳转列表。这些跳转命令包括跳转到标记、跳转到tag、搜索、替换、%、多于一行或一列的移动等。

 

3.3. 帮助

编写程序时,经常需要使用 man [section] funcname 来查看某个系统函数的帮助,在vim中使用 [section] K 命令直接查看当前词的manpage。

如果确实需要执行shell命令,可以在不离开vim环境和当前终端的情况下,使用 :!<cmd> 来执行一个shell命令,要获得一个shell,可以使用 :shell 。

 

3.4. 编译

说vim可以是集成开发环境,就是它可以方便的实现编辑-编译-编辑的循环。如果你的程序有makefile,使用 :make 命令来进行编译,而且更方便的是vim可以识别编译输出的错误,并定位到相应的位置。命令 :cc [num] 显示第num个完整的错误消息。

在错误列表中移动,可以使用 :cn (下一个错误)和 :cp (上一个错误)。列出整个错误列表使用命令 :clist 。

Vim保存多个错误列表,老的错误列表使用 :colder ,新的错误列表使用 :cnewer 。

这些命令被称为QuickFix命令,上面介绍的grep命令也使用这些命令。

 

 

4. 参考资料

       1. vim homepage http://vim.sourceforge.net/

      2. vim 文档主页http://vimdoc.sourceforge.net/

      3. vim 使用手册,也是vim的在线帮助文档,非常全面。http://vimdoc.sourceforge.net/dion/vimum.html

      4. vim的书,讲的非常详细。http://www.truth.sk/vim/vimbook-OPL.pdf

 

5. 关于作者

mounton @ www.ihere.org 当前关注于网络安全产品的开发、研究;软件开发过程等方面。您可以通过[email protected]和他联系。

 

本文来自:http://doc.linuxpk.com/80508.html 

 

 

 

 

 

 

 

 

 

 

来自:http://doc.linuxpk.com/80507.html

联系:linuxmine#gmail.com

分类:[vi]

 

-

 

用editplus时,用“另存为...”保存文件时,可以手工选择编码类型:ANSI、Unicode、UTF-8等。在用VIM时如何设置文件 的编码类型呢。在vim中,缺省情况下都会按ANSI方式保存,有时我们用vim编写一些jsp文件时,一不小心,就容易犯错误了,因为在我们的开发团队 中,是统一使用utf-8编码的,如果用ansi方式保存了,在网页的显示时就会出现乱码问题。

所以如果不清楚自己的缺省编码设置,可以手工输入设置命令:

:set fileencoding=utf-8

然后再保存就行了:

:w

这样无论之前的编码是什么,都会转换成utf-8保存。

如果希望缺省保存方式就是utf-8,就需要在_vimrc中加入以下设置:

set encoding=utf-8

set fileencoding=utf-8

set fileencodings=ucs-bom,utf-8,chinese

把这三行放在_vimrc的最开始的位置比较好。

取消高亮:

:set nohls

本文来自:http://doc.linuxpk.com/80507.html

以上是关于VIM使用入门(汇集)的主要内容,如果未能解决你的问题,请参考以下文章

Vim编辑器简单使用入门教程

Vim 入门使用

Vim快速入门

入门VMware Workstation下的Debian学习之Vim简单使用

Vim 基本命令入门-如何使用Vi/Vim文本编辑器

Vim实用技巧:使用模式入门篇(第2版)