Use Vim as a Python IDE

Use Vim as a Python IDE

I love vim and often use it to write Python code. Here are some useful plugins and tools for building a delightful vim python environment, escpecially for Vim8:html

我喜欢vim,常常用它来编写Python代码。如下是一些有用的插件和工具,用于构建使人愉快的vim-python环境,尤为是vim8:java

As you can see, tmux is also one of my favourite tools in terminal.python

如您所见,tmux也是我在终端中最喜欢的工具之一。c++


Syntax Checking

If you use Vim8, w0rp/ale is a better option than syntastic, for it utilizes the async feature in Vim8, you will never get stuck due to the syntax checking. It’s similar to flycheck in emacs, which allows you to lint while you type.git

若是您使用Vim8, w0rp/ale是比syntastic更好的选择,由于它利用了Vim8中的异步特性,您永远不会由于语法检查而被卡住。它相似于emacs中的flycheck,容许您在键入时进行lint。github

(taken from ale)编程


Code Formatter

google/yapf can be used to format python code. Make a key mapping as bellow, then you can format your python code via <LocalLeader> =.vim

能够使用google/yapf格式化python代码。将键映射设置为bellow,而后能够经过' = '格式化python代码。bash

autocmd FileType python nnoremap <LocalLeader>= :0,$!yapf<CR>

You can also take a look at Chiel92/vim-autoformat.服务器


Sort Import

timothycrosley/isort helps you sort imports alphabetically, and automatically separated into sections. For example, use <LocalLeader>i to run isort on your current python file:

timothycrosley/isort帮助您按字母顺序对导入进行排序,并自动将其分红几个部分。例如,使用' i '在当前python文件上运行isort:

autocmd FileType python nnoremap <LocalLeader>i :!isort %<CR><CR>

Or you can use its vim plugin: fisadev/vim-isort.

Update: ALE now has a command ALEFix for autofixing. Concerning code formatter and sort import, you could do that by merely configuring ALE properly. I’d love to put these in ftplugin/python.vim:

ALE如今有一个命令' ALEFix '用于自动修复。关于code formatter和sort import,您能够经过正确配置ALE来实现这一点。我想把这些放到ftplugin/python.vim:

let b:ale_linters = ['flake8']
let b:ale_fixers = [
\   'remove_trailing_lines',
\   'isort',
\   'ale#fixers#generic_python#BreakUpLongLines',
\   'yapf',
\]

nnoremap <buffer> <silent> <LocalLeader>= :ALEFix<CR>

If you want to fix files automatically on save:

若是你想修复文件自动保存:

let g:ale_fix_on_save = 1

Now you have the support of syntax checking and autofixing with one ALE! As a matter of fact, ALE also has a plan to support auto-completion via LSP. Keep watching this amazing project if you are interested.

如今,您已经支持语法检查和自动修复与一个ALE!事实上,ALE还计划经过LSP支持自动完成。若是你感兴趣,请继续观看这个精彩的项目。


Auto Completion

Valloric/YouCompleteMe is a good way to provide code auto completion. It has several completion engines, aside from Python, C, C++, Rust, Go and Javascript are also supported. Whereas a bunch of people also think YCM is too huge and need to be compiled, then jedi-vim is an alternative. They all use jedi as their backend.

(from jedi-vim)

What’s more, I know many people use Shougo/deoplete.nvim. Thanks to the async API, some more hopeful completion plugins are borned:

maralla/completor.vim is an code completion framework for Vim8, and support NeoVim too.

roxma/nvim-completion-manager also provides experimental support for Vim8.

roxma/nvim-completion-manager 还为Vim8提供了实验支持。

prabirshrestha/asyncomplete.vim is a fork of nvim-completion-manager in pure vim script with python dependency removed.

prabirshrestha/asyncomplete.vim是纯vim脚本中的一个nvim- completemanager分支,去掉了python依赖项。

nvim-completion-manager (from NCM)

Update: Unfortunately, NCM is not maintained any more.

*更新:*不幸的是,[NCM](https://github.com/roxma/nvim-comple-manager/issues/12# issuecom-382334422)再也不维护了。

Update again: ncm2, the successor of NCM, comes out! coc.nvim is also promising.


Quick Run

If use Vim8, you can execute python file asynchronously by skywind3000/asyncrun.vim and output automatically the result to the quickfix window like this:

若是使用Vim8,您能够经过skywind3000/asyncrun.vim异步执行python文件,并将结果自动输出到quickfix窗口,以下所示:

" Quick run via <F5>
nnoremap <F5> :call <SID>compile_and_run()<CR>

function! s:compile_and_run()
    exec 'w'
    if &filetype == 'c'
        exec "AsyncRun! gcc % -o %<; time ./%<"
    elseif &filetype == 'cpp'
       exec "AsyncRun! g++ -std=c++11 % -o %<; time ./%<"
    elseif &filetype == 'java'
       exec "AsyncRun! javac %; time java %<"
    elseif &filetype == 'sh'
       exec "AsyncRun! time bash %"
    elseif &filetype == 'python'
       exec "AsyncRun! time python %"
    endif
endfunction

" Deprecated:
" augroup SPACEVIM_ASYNCRUN
"     autocmd!
"    " Automatically open the quickfix window
"     autocmd User AsyncRunStart call asyncrun#quickfix_toggle(15, 1)
" augroup END
"
" asyncrun now has an option for opening quickfix automatically
let g:asyncrun_open = 15

For neovim, neomake/neomake is worthy of trying. Here is the description from neomake’s README:

对于neovim, neomake/neomake值得一试。如下是neomake的自述:

It is intended to replace the built-in :make command and provides functionality similar to plugins like syntastic and dispatch.vim. It is primarily used to run code linters and compilers from within Vim, but can be used to run any program.

Another approach is to use TMUX. The idea is simple: it can split your terminal screen into two. Basically, you will have one side of your terminal using Vim and the other side will be where you run your scripts.

PS: 另外一种方法是使用TMUX。这个想法很简单:它能够把你的终端屏幕一分为二。基本上,终端的一端使用Vim,另外一端运行脚本。


Enhance the default python syntax highlighting

python-mode/python-mode provides a more precise python syntax highlighting than the defaults. For example, you can add a highlighting for pythonSelf .

python-mode/python-mode提供了比默认值更精确的python语法高亮显示。例如,您能够为“pythonSelf”添加高亮显示。

hi pythonSelf  ctermfg=68  guifg=#5f87d7 cterm=bold gui=bold

For more customized python syntax highlightings, please see space-vim-dark theme and syntax/python.vim in python-mode/python-mode . You can also put them after color command.

更多定制的python语法高亮显示,请参见[space-vim-dark主题](https://github.com/liuchengxu/spacevim-dark/blob/aea40e6518a569911a63e9c41104d27e/colors/spacevim-dark.vim #L318-L337)和syntax/python。vim in python-mode/python-mode。你也能够把它们放在颜色命令以后.

Actually, python-mode contains tons of stuff to develop python applications in Vim, e.g., static analysis, completion, documentation, and more. (But personally, I prefer to obtain the functionalities by some other better plugins.)

实际上,python模式包含了大量在Vim中开发python应用程序的内容,例如静态分析、完成、文档等等。(但就我我的而言,我更喜欢经过一些更好的插件来得到这些功能。)


Python text objects

vim-pythonsense provides text objects and motions for Python classes, methods, functions, and doc strings.

vim-pythonsense为Python类、方法、函数和doc字符串提供文本对象和运动。


LSP

The concept of Language Server Protocol has been around for quite a while, many languages already have a decent LSP support. So far LSP is the only way to bring in various features similar to IDE for the text editors in a standard way. To do that, you need to install the correspoding language server and a LSP client to interact with it.

*Language Server Protocol的概念已经存在很长一段时间了,许多语言已经有了不错的LSP支持。到目前为止,LSP是以标准方式为文本编辑器引入各类相似IDE的特性的唯一方法。为此,您须要安装correspoding语言服务器和一个LSP客户机来与之交互。*

Vim LSP client Implementation Support
LanguageClient-neovim Rust vim/neovim
ale VimL vim/neovim
vim-lsp VimL vim/neovim
neovim’s built-in LSP support Lua neovim only

LCN implements the LSP client in Rust, so it obviously has an outstanding performance compared to others written in vimscript or lua. Most LSP clients are usable now, but far from perfect:

LCN在Rust中实现了LSP客户机,所以与其余使用vimscript或lua编写的客户机相比,LCN显然具备出色的性能。大多数LSP客户端如今都是可用的,但还远远不够完美:

  • simple and crude UI
  • poor performance

Still a long way to go :).


Summary

There are also some neccessary general programming plugins, e.g.

也有一些必要的通用编程插件,例如。

Although vim is great and many plugins are productive, IDE is still my first choice when it comes to refactoring code and debugging:). Some useful links for debugging python:

For detailed vim configuration, please refer to space-vim. Enable ycmd/lsp, auto-completion, syntax-checking, python, programming Layer , then you could get a nice vim environment for python like the above screenshot. Enjoy!

有关vim的详细配置,请参阅space-vim。启用ycmd/lsp、自动完成、语法检查、python、编程层,而后您就能够获得一个适合python的vim环境,就像上面的截图同样。享受吧!

相关文章
相关标签/搜索