VIM笔记

把一直使用中的vim配置做个GIT入库管理,也把之前积累在机器上的文档,做个汇总。

https://github.com/wujuguang/kyvim

1. 安装完整版vim

vi和vim的区别?
在Linux自带有vi编辑器,而vim是指vi improved,即vi升级版。区别在于vi指令和功能较vim简单,正因如此才有了vi improved。
Ubuntu自带的vi编辑器是vim.tiny,也就是vim最基本功能,几乎等同于vi。而在Ubuntu中vi命令指向的是vim。

如何使用apt安装vim?
Linux分支之Debian及其衍生版本中可以通过apt管理包,apt是advanced packaging tools的缩写。Ubuntu作为Debian分支,使用apt命令管理包是很方便的。
使用apt-get命令安装包时会发现有几个包可供选择:vim,vim-gnome,vim-gtk,vim-tiny。据说vim包其实就是vim.basic,该版本不支持GUI。建议安装的是vim-gnome。

apt搜索包:$ apt-cache search package_name
apt安装包:$ apt-get install vim-gnome
安装完成后,vi命令会指向vim.gnome。

2. 安装ctags
$ apt-get install ctags
ctags用于支持taglist,使用ctags可以在变量之间跳跃。

3. 安装pydiction
pydiction用来实现代码补全和语法提示功能。pydiction不能通过apt安装,需要自行下载安装。
在GitHub下载源码,可以使用Git迁出到本地,或者下载zip包自行解压,地址为:https://github.com/rkulla/pydiction
pydiction可以让vim自动补全Python代码,无论是关键字,标准库还是第三方库。它主要包含3个文件:
  python_pydiction.vim: vim插件文件。
  complete-dict: 一个字典文件,包含了Python的关键字和模块。插件引用的内容即来自于此。
  pydiction.py: 一个py脚本,运行此文件可以增加新的模块到complete-dict字典中。

如何安装?
Linux/Unix系统:将python_pydiction.vim文件复制到 ~/.vim/after/ftplugin 目录下。如果该目录不存在,则创建它,vim会自动在此目录下搜索。
Windows系统:将python_pydiction.vim文件复制到 C:\vim\vimfiles\ftplugin 目录下(假设你的Vim安装路径为C:\vim)
除此之外的另两个文件complete-dict和pydiction.py可以放置到任何你想放置的位置,但在ftplugin目录下最好只存放python_pydiction.vim而不应该还有其他文件。

以下为pydiction.zip解压后执行的安装命令(我的complete-dict和pydiction.py放置在~/.vim目录下):
进入解压后的pydiction目录
$ cp after/ftplugin/python_pydiction.vim ~/.vim/after/ftplugin
$ cp complete-dict ~/.vim
$ cp pydiction.py ~/.vim

4. 编辑配置文件:
编辑~/.vimrc文件,如果不存在则创建。添加以下内容:
let Tlist_Auto_Highlight_Tag=1  
let Tlist_Auto_Open=1  
let Tlist_Auto_Update=1  
let Tlist_Display_Tag_Scope=1  
let Tlist_Exit_OnlyWindow=1  
let Tlist_Enable_Dold_Column=1  
let Tlist_File_Fold_Auto_Close=1  
let Tlist_Show_One_File=1  
let Tlist_Use_Right_Window=1  
let Tlist_Use_SingleClick=1  
nnoremap <silent> <F8> :TlistToggle<CR>
   
filetype plugin on  
autocmd FileType python set omnifunc=pythoncomplete#Complete  
autocmd FileType javascrīpt set omnifunc=javascriptcomplete#CompleteJS  
autocmd FileType html set omnifunc=htmlcomplete#CompleteTags  
autocmd FileType css set omnifunc=csscomplete#CompleteCSS  
autocmd FileType xml set omnifunc=xmlcomplete#CompleteTags  
autocmd FileType php set omnifunc=phpcomplete#CompletePHP  
autocmd FileType c set omnifunc=ccomplete#Complete  

let g:pydiction_location=‘~/.vim/tools/pydiction/complete-dict‘  
set autoindent
set tabstop=4  
set shiftwidth=4  
set expandtab  
set number
filetype plugin on:表示开启插件。
let g:pydiction_location=‘~/.vim/tools/pydiction/complete-dict‘ : 写入你存放complete-dict的绝对路径。

如果是Pydiction 1.0以前的版本,要确保vimrc不包含以下代码:
if has("autocm")
    autocmd FileType python set complete+=k/path/to/pydiction iskeyword+=.,(
endif " has("autocmd")

5. 进击的.vimrc
以上针对Python配置的vim算是基本完成,但事情可以做得更完善一点,进一步将你的vim变得更好用。(以下进击不仅针对Python,而是对vim自身的完善。)

# vi ~/.vimrc
添加:set foldmethod=indent
关闭开启时默认折叠命令,在.vimrc写入:set nofoldenable
这样,再编辑 python 文件时会发现代码已经作了折叠处理。下面是有关折叠的一些命令:

zo: 打开光标位置的折叠代码;
zc: 折叠光标位置的代码;
zr: 将文件中所有折叠的代码打开;
zm: 将文件中所有打开的代码折叠;
zR: 作用和 zr 类似,但会打开子折叠(折叠中的折叠);
zn: 作用和 zm 类似,但会关闭子折叠;
zi: 折叠与打开操作之间的切换命令;

6. 浏览文件
NERDTree提供了丰富的键盘操作方式来浏览和打开文件,我简单介绍一些常用的快捷键:
和编辑文件一样,通过h j k l移动光标定位
o 打开关闭文件或者目录,如果是文件的话,光标出现在打开的文件中
go 效果同上,不过光标保持在文件目录里,类似预览文件内容的功能
i和s可以水平分割或纵向分割窗口打开文件,前面加g类似go的功能
t 在标签页中打开
T 在后台标签页中打开
p 到上层目录
P 到根目录
K 到同目录第一个节点
J 到同目录最后一个节点
m 显示文件系统菜单(添加、删除、移动操作)
? 帮助
q 关闭

技巧:

1、搜索或者替换后取消高亮的关键词
搜索和替换后关键词会高亮显示,搜索结束后也不会消失,要取消高亮可以通过命令:noh
另类方法:你可以搜索一个不存在字符的来让高亮取消/asdasdasd

2、整体缩进一段代码
先得到要缩进的开始行号和结束行号(比如开始行3 结束行9)然后用
3,9>> 向右增加一个tab的缩进
3,9<< 向左减少2个tab的缩进

3、让VIM不生成备份文件(~文件)
:set nobackup
另外,也可以不关掉backup而是设置backupdir将备份文件统一存放到一个目录下,比如
set backupdir=d:\Vim\tmp

-u <vimrc>        使用 <vimrc> 替代任何 .vimrc
-U <gvimrc>        使用 <gvimrc> 替代任何 .gvimrc

VIM插件:
pathogen:插件管理,管理所有的插件。
首先,在vim runtime目录下创建两新目录 ~/.vim/autoload 和 ~/.vim/bundle。
$ mkdir -p ~/.vim/autoload ~/.vim/bundle
其次,拷贝源包中 autoload/pathogen.vim 到 ~/.vim/autoload 目录下。
$ cp autoload/pathogen.vim ~/.vim/autoload/pathogen.vim
要记得把以下内容加入到vimrc文件中:execute pathogen#infect()
此后所有vim插件目录可以解压到 ~/.vim/bundle 中, 它会被自动追加到"runtimepath"中。
项目地址:https://github.com/tpope/vim-pathogen

vim-pep8:python的 PEP8 语法检查插件,可以用用。
项目地址:http://www.vim.org/scripts/script.php?script_id=2914

supertab:功能增强,增强tab键的功能,建议安装。
项目地址:https://github.com/ervandew/supertab

supertab:让tab键可以飞起来。
syntastic:保存文件时检查语法的插件。
项目地址:https://github.com/scrooloose/syntastic
本来我之前一直是用 pyflakes-vim 这个python语法检查插件的,非常好用,不过最近在它的项目主页上发现 作者已经不推荐使用这个了。并给出了替代品syntastic。
syntastic支持很多语言的语法检查功能(python方面还是使用了pyflakes)。缺点是速度有点慢,每次保存文件 的时候都会有点卡,比单独使用pyflakes-vim速度要差一些。

neocomplcache-clang:解决clang_complete和neocomplcache的冲突。
neocomplcache:关键字补全、文件路径补全、tag补全等等,各种,非常好用,速度超快。
vim-powerline:超有爱的状态栏。
buferexplorer:方便浏览buffer的插件。
TagHightlight :根据生成的Tag文件,高亮类、变量、函数和关键字。
TagBar:该插件生成函数、变量列表。
下面是我在配置文件中关于tagbar的配置,让tagbar可以在加载代码时自动打开
nmap <Leader>tb :TagbarToggle<CR>
let g:tagbar_ctags_bin=‘/usr/bin/ctags‘
let g:tagbar_width=30
autocmd BufReadPost *.cpp,*.c,*.h,*.hpp,*.cc,*.cxx call tagbar#autoopen()

以下两个淘汰,了解而已:
taglist
之前有一个插件叫TagList,有点不太好用,而TagBar是一个taglist的替代品,比taglist更适合c++使用,函数能够按类区分,支持按类折叠显示等,显示结果清晰简洁,强烈推荐,下载地址如下:http://www.vim.org/scripts/script.php?script_id=3465

python_fold
将Python代码折叠,Python的class,function,以及在{{{,}}}标记的内容将被折叠。
下载 python_fold 插件:http://www.vim.org/scripts/script.php?script_id=515 下载后得到 python_fold.vim。
# cp python_fold.vim  /usr/share/vim/vim70/plugin/

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。