您的位置:首页 > 编程语言 > Python开发

vim打造成PYTHON IDE

2017-09-16 22:47 591 查看
VIM基础设置
1 基础学习资料

2 验证vim的安装

插件管理
vim默认的插件安装方式

通过插件Vundle来管理插件

界面美化

文件系统与工程管理

代码阅读与分析

代码开发

其他辅助

参考资料

1. VIM基础设置

1.1 基础学习资料

vimtutor入门学习, vim用户手册与参考手册

在shell下直接运行
$ vimtutor
就可以使用vimtutor来进行入门练习。vim usr_doc与reference 可以在vim命令行中使用
:help
来查询使用。

一本关于vim核心技巧的书:Vm实用技巧 (Practice Vim: Edit Text at the Speed of Thought)

包含了编辑技巧,快速移动技巧,文件管理技巧以及编程相关技巧,以vim提供的核心功能为基础,基本不涉及额外插件的使用

vi/vim使用进阶 http://easwy.com/blog/archives/advanced-vim-skills-catalog/

基础vim scripting

笨方法学Vimscript

1.2 验证vim的安装

$ vim --version
VIM - Vi IMproved 7.4 (2013 Aug 10, compiled Nov 24 2016 16:42:57)
Included patches: 1-52
Extra patches: 8.0.0056
Modified by pkg-vim-maintainers@lists.alioth.debian.org
Compiled by buildd@
Huge version with GTK2-GNOME GUI.  Features included (+) or not (-):
+acl             +farsi           +mouse_netterm   +syntax
+arabic          +file_in_path    +mouse_sgr       +tag_binary
+autocmd         +find_in_path    -mouse_sysmouse  +tag_old_static
+balloon_eval    +float           +mouse_urxvt     -tag_any_white
+browse          +folding         +mouse_xterm     +tcl
++builtin_terms  -footer          +multi_byte      +terminfo
+byte_offset     +fork()          +multi_lang      +termresponse
+cindent         +gettext         -mzscheme        +textobjects
+clientserver    -hangul_input    +netbeans_intg   +title
+clipboard       +iconv           +path_extra      +toolbar
+cmdline_compl   +insert_expand   +perl            +user_commands
+cmdline_hist    +jumplist        +persistent_undo +vertsplit
+cmdline_info    +keymap          +postscript      +virtualedit
+comments        +langmap         +printer         +visual
+conceal         +libcall         +profile         +visualextra
+cryptv          +linebreak       +python          +viminfo
+cscope          +lispindent      -python3         +vreplace
+cursorbind      +listcmds        +quickfix        +wildignore
+cursorshape     +localmap        +reltime         +wildmenu
+dialog_con_gui  +lua             +rightleft       +windows
+diff            +menu            +ruby            +writebackup
+digraphs        +mksession       +scrollbind      +X11
+dnd             +modify_fname    +signs           -xfontset
-ebcdic          +mouse           +smartindent     +xim
+emacs_tags      +mouseshape      -sniff           +xsmp_interact
+eval            +mouse_dec       +startuptime     +xterm_clipboard
+ex_extra        +mouse_gpm       +statusline      -xterm_save
+extra_search    -mouse_jsbterm   -sun_workshop    +xpm
system vimrc file: "$VIM/vimrc"
user vimrc file: "$HOME/.vimrc"
2nd user vimrc file: "~/.vim/vimrc"
user exrc file: "$HOME/.exrc"
system gvimrc file: "$VIM/gvimrc"
user gvimrc file: "$HOME/.gvimrc"
2nd user gvimrc file: "~/.vim/gvimrc"
system menu file: "$VIMRUNTIME/menu.vim"
fall-back for $VIM: "/usr/share/vim"
Compilation: gcc -c -I. -Iproto -DHAVE_CONFIG_H -DFEAT_GUI_GTK  -pthread -I/usr/include/gtk-2.0 -I/usr/lib/x86_64-linux-gnu/gtk-2.0/include -I/usr/include/atk-1.0 -I/usr/include/cairo -I/usr/include/gdk-pixbuf-2.0 -I/usr/include/pango-1.0 -I/usr/include/gio-unix-2.0/ -I/usr/include/freetype2 -I/usr/include/glib-2.0 -I/usr/lib/x86_64-linux-gnu/glib-2.0/include -I/usr/include/pixman-1 -I/usr/include/libpng12 -I/usr/include/harfbuzz   -pthread -DORBIT2=1 -D_REENTRANT -I/usr/include/libgnomeui-2.0 -I/usr/include/libart-2.0 -I/usr/include/gconf/2 -I/usr/include/gnome-keyring-1 -I/usr/include/libgnome-2.0 -I/usr/include/libbonoboui-2.0 -I/usr/include/libgnomecanvas-2.0 -I/usr/include/gtk-2.0 -I/usr/include/gdk-pixbuf-2.0 -I/usr/include/gnome-vfs-2.0 -I/usr/lib/x86_64-linux-gnu/gnome-vfs-2.0/include -I/usr/include/dbus-1.0 -I/usr/lib/x86_64-linux-gnu/dbus-1.0/include -I/usr/include/glib-2.0 -I/usr/lib/x86_64-linux-gnu/glib-2.0/include -I/usr/include/orbit-2.0 -I/usr/include/libbonobo-2.0 -I/usr/include/bonobo-activation-2.0 -I/usr/include/libxml2 -I/usr/include/pango-1.0 -I/usr/include/gail-1.0 -I/usr/include/harfbuzz -I/usr/include/freetype2 -I/usr/include/atk-1.0 -I/usr/lib/x86_64-linux-gnu/gtk-2.0/include -I/usr/include/cairo -I/usr/include/gio-unix-2.0/ -I/usr/include/pixman-1 -I/usr/include/libpng12     -g -O2 -fstack-protector --param=ssp-buffer-size=4 -Wformat -Werror=format-security -U_FORTIFY_SOURCE -D_FORTIFY_SOURCE=1     -I/usr/include/tcl8.6  -D_REENTRANT=1  -D_THREAD_SAFE=1  -D_LARGEFILE64_SOURCE=1
Linking: gcc   -L. -Wl,-Bsymbolic-functions -Wl,-z,relro -L/build/buildd/ruby1.9.1-1.9.3.484/debian/lib -rdynamic -Wl,-export-dynamic -Wl,-E  -Wl,-Bsymbolic-functions -Wl,-z,relro -Wl,--as-needed -o vim   -lgtk-x11-2.0 -lgdk-x11-2.0 -latk-1.0 -lgio-2.0 -lpangoft2-1.0 -lpangocairo-1.0 -lgdk_pixbuf-2.0 -lcairo -lpango-1.0 -lfontconfig -lgobject-2.0 -lglib-2.0 -lfreetype     -lgnomeui-2 -lSM -lICE -lbonoboui-2 -lgnomevfs-2 -lgnomecanvas-2 -lgnome-2 -lpopt -lbonobo-2 -lbonobo-activation -lORBit-2 -lart_lgpl_2 -lgtk-x11-2.0 -lgdk-x11-2.0 -latk-1.0 -lgio-2.0 -lpangoft2-1.0 -lpangocairo-1.0 -lgdk_pixbuf-2.0 -lcairo -lpango-1.0 -lfontconfig -lfreetype -lgconf-2 -lgthread-2.0 -lgmodule-2.0 -lgobject-2.0 -lglib-2.0   -lSM -lICE -lXpm -lXt -lX11 -lXdmcp -lSM -lICE  -lm -ltinfo -lnsl  -lselinux  -lacl -lattr -lgpm -ldl  -L/usr/lib -llua5.2 -Wl,-E  -fstack-protector -L/usr/local/lib  -L/usr/lib/perl/5.18/CORE -lperl -ldl -lm -lpthread -lcrypt -L/usr/lib/python2.7/config-x86_64-linux-gnu -lpython2.7 -lpthread -ldl -lutil -lm -Xlinker -export-dynamic -Wl,-O1 -Wl,-Bsymbolic-functions  -L/usr/lib/x86_64-linux-gnu -ltcl8.6 -ldl -lz -lpthread -lieee -lm -lruby-1.9.1 -lpthread -lrt -ldl -lcrypt -lm  -L/usr/lib


比如看到
+python
代表包含了python支持的特性(feature)

在vim命令行中查看是否支持某项特性可以使用
:echo has('python')
,如果输出 1 则表示构建出的 vim 已支持 python,反之,0 则不支持。

2. 插件管理

vim默认的插件安装方式

vim 自身希望通过在 .vim/ 目录中预定义子目录管理所有插件(比如,子目录 doc/存放插件帮助文档、plugin/ 存放通用插件脚本),vim的各插件打包文档中通常也包含上述两个(甚至更多)子目录,用户将插件打包文档中的对应子目录拷贝至 .vim/ 目录即可完成插件的安装。

通过插件Vundle来管理插件

具体参考

4.3.1 一般安装方法

安装插件的方法,

1.一般是 把源文件解压到 ~/.vim 就可以了

进入~/.vim/doc目录,在Vim命令行下运行”helptags .”命令。此步骤是将doc下的帮助文档加入到Vim的帮助主题中,这样我们就可以通过在Vim命令行中运行“help taglist.txt”查看taglist帮助。

4.3.2 通过vundle 管理

同过一个插件管理所有的插件 以官网 的readme 为准

https://github.com/VundleVim/Vundle.vim

网上有些例子里面的 命令和配置的和现在官网上的不一样了,

比如 下面这个链接里面 对与vimrc 文件配置的命令 似乎有点不一样 用 vundle 还是 plugin,

现在github上例子用的plugin 还有相关命令 也是变成PluginList 等 而不是 VundleList

http://blog.csdn.net/jiaolongdy/article/details/17889787/

附:参考文献

Vundle项目

vim-scripts维护的GitHub repo

3. 界面美化

配色方案

vim中

:colorscheme 显示 当前配色

:colorscheme {yourscheme} 设置 你想要的配饰

gvim中 可以通过菜单设置

?如何列出所有可用的配色?

配色方案可以和你正在使用的基础配色共同使用。GUI模式可以尝试solarized方案, 终端模式可以尝试Zenburn方案:

Plugin ‘jnurmine/Zenburn’

Plugin ‘altercation/vim-colors-solarized’

接下来,只需要添加一点逻辑判断,确定什么模式下使用何种方案就可以了:

if has(‘gui_running’)

set background=dark

colorscheme solarized

else

colorscheme zenburn

endif

4. 文件系统与工程管理

用NerdTree时隐藏 .pyc文件

还想隐藏.pyc文件?那么再添加下面这行代码吧:

let NERDTreeIgnore=[‘.pyc′,′\~’, ‘.swp$’] “ignore files in NERDTree

5. 代码阅读与分析

打开 语法高亮

:syntax on

for python

语法高亮加强???不懂 这样就可支持内置函数,数字,空格,异常的语法??

” For full syntax highlighting:

let python_highlight_all=1

syntax on

显示行开启显示行号:

set nu

代码折叠

:help usr_28.txt

:help fold.txt

http://blog.csdn.net/wooin/article/details/2004470

手动折叠

Try it out: Position the cursor in a paragraph and type:

zfap

You will see that the paragraph is replaced by a highlighted line. You have

created a fold. zf is an operator and ap a text object selection. You

can use the zf operator with any movement command to create a fold for the

text that it moved over. zf also works in Visual mode.

To view the text again, open the fold by typing:

zo

And you can close the fold again with:

zc

zf      F-old creation
zo      O-pen a fold
zc      C-lose a fold


za When on a closed fold: open it. When folds are nested, you

may have to use “za” several times. When a count is given,

that many closed folds are opened.

When on an open fold: close it and set ‘foldenable’. This

will only close one level, since using “za” again will open

the fold. When a count is given that many folds will be

closed (that’s not the same as repeating “za” that many

times).

zr  This will R-educe the folding.  The opposite is:
zm  This folds M-ore.  You can repeat "zr" and "zm" to open and close nested folds


of several levels.

If you have nested several levels deep, you can open all of them with:

zR This R-educes folds until there are none left. And you can close all folds

with:

zM This folds M-ore and M-ore.

set foldmethod=syntax

set foldlevel=100 ” 启动vim时不要自动折叠代码

试了一下, c文件 管用, python文件怎么不管用???

–》 原因 The Python syntax definition that comes bundled with Vim doesn’t contain any fold directives at all,

python 折叠

针对pythod的折叠插件

tmhedberg/SimpylFold

光用 foldmethod=indent 效果不是太好,对此进行改进的插件

https://github.com/tmhedberg/SimpylFold

Plugin ‘tmhedberg/SimpylFold’

不要忘记执行安装命令::PluginInstall

专业贴士: 希望看到折叠代码的文档字符串?

let g:SimpylFold_docstring_preview=1

tagbar

https://github.com/majutsushi/tagbar/

TagList

https://github.com/vim-scripts/taglist.vim

tagbar?? 功能类似? 也是依赖tags的,ctags支持的文件 它就支持

https://github.com/majutsushi/tagbar

Plug ‘majutsushi/tagbar’ 也有python的用户使用这个

6. 代码开发

语法检查

syntastic(https://github.com/scrooloose/syntastic)

SuperTab (如果用了 youcompleteme来做代码补全就不需要了)

通过tab按键 实现补全,上面提到过

自动补全

davidhalter/jedi-vim

python autocompletion 和 goto definition

自动补全

https://github.com/Valloric/YouCompleteMe

‘Valloric/YouCompleteMe’ 这个就不需要supertab了

https://github.com/Valloric/YouCompleteMe

支持Python自动补全的最好插件是YouCompleteMe。我们再次使用Vundle安装:

Bundle ‘Valloric/YouCompleteMe’

YouCompleteMe插件其实底层使用了一些不同的自动补全组件(包括针对Python开发的Jedi),另外要安装一些C库才能正常工作。插件官方文档提供了很好的安装指南,我就不在这里重复了。切记跟随文档的步骤进行安装。

安装完成后,插件自带的设置效果就很好,但是我们还可以进行一些小的调整:

let g:ycm_autoclose_preview_window_after_completion=1

map g :YcmCompleter GoToDefinitionElseDeclaration

上面的第一行确保了在你完成操作之后,自动补全窗口不会消失,第二行则定义了“转到定义”的快捷方式。

snipmate https://github.com/garbas/vim-snipmate

插入代码片段?

python 缩进

tabstop 等的设置 要设置成4个空格的宽度

符合 pep8

https://github.com/vim-scripts/indentpython.vim

pep8 代码风格检查

还可以通过这个小巧的插件,添加PEP8代码风格检查:

Plugin ‘nvie/vim-flake8’

vim-flake8

https://github.com/nvie/vim-flake8

vim-flake8 is a Vim plugin that runs the currently open file through Flake8, a static syntax and style checker for Python source code. It supersedes both vim-pyflakes and vim-pep8.

Flake8 is a wrapper around PyFlakes (static syntax checker), PEP8 (style checker) and Ned’s MacCabe script (complexity checker).

和下面的python-mode有重合?

结合上面的提到的 语法检查 syntastic

标识不必要的空白和tab?

” Use the below highlight group when displaying bad whitespace is desired.

highlight BadWhitespace ctermbg=red guibg=red

” Display tabs at the beginning of a line in Python mode as bad.

au BufRead,BufNewFile .py,.pyw match BadWhitespace /^\t+/

” Make trailing whitespace be flagged as bad.

au BufRead,BufNewFile .py,.pyw,.c,.h match BadWhitespace /\s+$/

7. 其他辅助

综合方案 Plugin ‘klen/python-mode’ ?

https://github.com/klen/python-mode. 重定向到

https://github.com/python-mode/python-mode

语法检查,pep8风格,重构refactoring,代码补全依靠 rope 以及这个插件? https://github.com/python-rope/ropevim

用了很多其他python库文件,去检查

代替了 klen/rope-vim

超级搜索

想要在Vim中搜索任何文件?试试ctrlP插件吧:

Plugin ‘kien/ctrlp.vim’

Git集成

想要在Vim中执行基本的Git命令?vim-fugitive插件则是不二之选。

Plugin ‘tpope/vim-fugitive’

请看Vimcasts的这部视频,了解更多情况 。

Powerline状态栏

Powerline是一个状态栏插件,可以显示当前的虚拟环境、Git分支、正在编辑的文件等信息。

这个插件是用Python编写的,支持诸如zsh、bash、tmux和IPython等多种环境。

Plugin ‘Lokaltog/powerline’, {‘rtp’: ‘powerline/bindings/vim/’}

8. 参考资料

所需即所获:像 IDE 一样使用 vim

主要是针对C/C++的,但是有些功能是通用的,完整的介绍了程序开发所需的各个功能和如何通过配置vim来实现,讲的很系统。

Vim与Python真乃天作之合:打造强大的Python开发环境

Vim as a python IDE 主要借助插件python-mode

两个命令把 Vim 打造成 Python IDE

https://github.com/fisadev/fisa-vim-config

http://fisadev.github.io/fisa-vim-config/

用 Vim 写 Python 的最佳实践是什么?

https://www.zhihu.com/question/19655689

手把手教你把Vim改装成一个IDE编程环境(图文)
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  python vim