关山难越,谁悲失路之人;萍水相逢,尽是他乡之客。
百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程教程 > 技术文章 > 正文

一文让你对vim产生兴趣

guanshanw 2023-08-20 13:45 89 浏览 0 评论

引言:现在有很多成熟的IDE,pycharm、vs code、atom、codeblocks,不同软件在不同方向各有优势,但是当使用服务器时这些桌面版IDE就很难发挥优势,推荐vim的理由是:当时用无桌面版Linux时免不了与vim打交道,如果在windows下开发好用版本控制软件提交到服务器下这样太麻烦,用sftp上传到服务器也需要多余的操作,使用vim能够让操作更加简洁方便,同时配置一些插件能够让vim自动补全、换行缩进等等,而且我觉得自动补全Python第三方库的速度能够达到pycharm级别,远比vs code要快,希望这篇文章能够让大家对vim产生兴趣,后期会不断分享计算机视觉、强化学习、优化算法、工具使用等方面的内容,感兴趣的可以关注一下微信公众号,会定期分享一些技术和工具,“平凡而诗意”。

常用命令

我觉得vim命令是一个让人又爱又恨的东西,突然从Windows下的鼠标操作切换到vim的Linux操作会感觉很不方便,有的时候甚至会误操作导致很大的坑。但是用习惯后再回到window下回发现会不自觉的使用这些命令,可见,这些命令的确带来了便携性,vim命令有很多,一下子也记不完,这里我就总结一些我个人常用的命令。

1. 注释

一文让你对vim产生兴趣

手动输入注释符:

单行注释:可以直接在行前添加注释符比如 #

多行注释:ctrl+v 进入视图模式, 然后shift+i,输入注释符,最后按Esc

也可以使用替换命令,详细的请看第3条:

# 注释,以Python为例# 注释m到n行:m,ns/^/#/g # 解除注释:m,ns/^#//g# 注释整个文档:1,$s/^/#/g# 还有更高效快速的方法:%s/^/#/g

2. 多窗口

写代码过程中要打开多个窗口,如果反复关闭开启会很麻烦,vim可以使用多窗口

直接打开多个文件:

vim -On file1 file2 ...

已经打开一个文件之后再大开一个文件:

# 可以打开本地文件:e file# 也可以打开远程文件:e ftp://host/*

多窗口切换文件:

下一个文件:bn上一个文件:bp

在另一窗口分割打开文件:

:split file

多窗口之间的切换:

# 依次切换ctrl+w+w # 双击w# 指定方向切换先ctrl+w,松开,然后按上下左右键选择

3. 查找与替换

# 查找字符串/str# 替换# 替换当前行,其中g是替换标志,代表global的意思,也可以换成c:需要确认;i:大小写不敏感;I:大小写敏感:s/old/new/g# 全局替换:%s/old/new/g# 替换特定行:m,ns/old/new/g# 选择区域替换:'<,'>s/old/new/g #先visual模式下选择要替换的区域

4. 与shell交互

临时退出:ctrl+z回到vim:fg执行shell命令:!# 命令模式下:! ls ./

5. 插入

# 在当前行首插入I # 也就是shift+i# 在当前位置行尾插入A# 在当前字符所在位置插入i# 在当前字符之后插入a# 在当前行的前一行插入O # shift+ o# 在当前行的后一行插入o

6. 撤销和重做

# 撤销操作u# 撤销对整行的操作U# 重做(把撤销的动作撤销)ctrl+r

7. 移动

# 移动到文本头部gg# 移动到尾部G #Windows下同shift+g# 向前移动一个单词w # 2w移动两个单词# 向后移动一个单词b# 移动到行首0# 移动到行尾$# 移动到段落头部(# 移动到段落尾部)

8. 对比差异

这一点和beyond compare类似:

vim -diff file1 file2

属性设置

可以对vim属性设置,使得每次打开vim时都能起作用,基本的属性设置比如高亮、缩进等,先贴上我的设置:

1. 进入home路径下

cd ~

2. 创建.vimrc文件

touch .vimrcvim .vimrc

3. 粘贴以下内容

set nocompatibleset numberset icset hlsearchset encoding=utf-8set fileencodings=utf-8,ucs-bom,GB2312,big5set autoindentset smartindentset scrolloff=2set showmatchset shiftwidth=4set tabstop=4set showmatchset cursorlineset autoreadsyntax on

这样保存退出后就生效了,网上有很多这一类的教程,创建.vimrc的作用是保证每次启动vim都可以起作用。


插件

工欲善其事必先利其器,无论是做Python还是c++开发,如果有一个好的IDE,那么效率将会得到大大的提升,如果想把vim用于轻量级IDE,那么插件是必不可少的,以下以vim配置Python3为例。

1. 检查vim版本是否符合

vim --version

在输出的信息检查以下是否有'+python3'字眼,如果没有说明vim版本太低不支持,需要卸载重新安装vim。

2. 安装Vundle插件管理器

个人认为Vundle 就如同maven之于Java、npm之于js、pip之于Python,安装了Vundle后方便后续安装插件。

首先克隆到指定目录:

git clone https://github.com/VundleVim/Vundle.vim.git ~/.vim/bundle/Vundle.vim# 如果克隆失败可以参考我的另外一篇文章,或者查看我的知乎专栏“”Lee先森的技术站”

Thinker:git一些报错解决方法[每一项都亲测,保证不踩坑]

其次,在~/.vimrc中输入如下内容:

set nocompatible " requiredfiletype off " required" set the runtime path to include Vundle and initializeset rtp+=~/.vim/bundle/Vundle.vimcall vundle#begin()" alternatively, pass a path where Vundle should install plugins"call vundle#begin('~/some/path/here')" let Vundle manage Vundle, requiredPlugin 'gmarik/Vundle.vim'" Add all your plugins here (note older versions of Vundle used Bundle instead of Plugin)" All of your Plugins must be added before the following linecall vundle#end() " requiredfiletype plugin indent on " required上述 Add all your plugins here (note older versions of Vundle used Bundle instead of Plugin)下面的一段空白处是用于添加其他插件。

3. 安装插件

首推YouCompleteMe,这个插件用于自动补全,速度补全速度可以达到pycharm的级别,但是这个插件安装十分麻烦,可以参考我的另外一篇文章:

另一篇文章可以查看我的知乎专栏“Lee先森的技术站”

Thinker:vim插件YouCompleteMe安装

然后在~/.vimrc中添加

Plugin 'Valloric/YouCompleteMe'

保存退出重新打开,在命令模式下输入:PluginInstall即可安装,左下角显示Done!即为完成,可以在紧接着下面添加如下设置:

let g:ycm_global_ycm_extra_conf = "~/.vim/bundle/YouCompleteMe/cpp/ycm/.ycm_extra_conf.py"let g:ycm_key_invoke_completion = ''let g:ycm_min_num_identifier_candidate_chars = 2let g:ycm_goto_buffer_command = 'horizontal-split'let g:ycm_seed_identifiers_with_syntax=1map <F2> :YcmCompleter GoTo<CR> # 按F2跳转到定义处let g:ycm_error_symbol = '>>'let g:ycm_warning_symbol = '>*'

其次是Autoformat这是一个自动格式化代码的工具,事先需要安装pep8:

pip install autopep8

其次在vimrc空白处添加:

Plugin 'Chiel92/vim-autoformat'nnoremap <F6> :Autoformat<CR> # 按F6自动格式化let g:autoformat_autoindent = 0let g:autoformat_retab = 0let g:autoformat_remove_trailing_spaces = 0

保存并退出,重新进入vim,命令模式下输入:PluginInstall

还有nerdtree这是一个目录树插件,可以给代码添加目录:

Plugin 'https://github.com/scrooloose/nerdtree'nnoremap <F3> :NERDTreeToggle<CR> # 按F3显示或隐藏目录autocmd bufenter * if (winnr("$") == 1 && exists("b:NERDTree") && b:NERDTree.isTabTree()) | q | endif

还有indentLine,这是一个缩进线插件,对于Python这种缩进要求很严格的语言来说很重要:

Plugin 'Yggdroot/indentLine'let g:indentLine_char='┆'let g:indentLine_enabled = 1注意:把上述内容添加到vimrc后需要关闭后重新打开,在命令模式下输入:PluginInstall,也可以用:Plugin '插件',例如:Plugin 'Yggdroot/indentLine'


总结:首先是自己做个笔记,如果能够帮到大家,当然十分荣幸;其次,好与不好,仁者见仁智者见智,每个人都会根据自己的需求和判断进行选择,vim插件管理器有很多,vundle、vim-plug、pathogen、vim addon manager等等,每一个都用过,也都对比过,vundle在高阶插件方面的确存在不足,但是基本使用大同小异,我觉得满足我使用足够了,而且我觉得使用比较简洁方便,各位看到的可以根据自己的需求选择插件管理器。

相关推荐

七条简单命令让您玩转Git
七条简单命令让您玩转Git

凭借着出色的协作能力、快速部署效果与代码构建辅助作用,Git已经得到越来越多企业用户的青睐。除了用于开发商业及消费级应用之外,众多科学及政府机构也开始尝试使用这...

2023-10-07 12:14 guanshanw

基本完整的关于Git分支branch的操作
基本完整的关于Git分支branch的操作

Git使用背景项目中要用到dev或者其他分支开发完代码,需要将该分支合并到master的需求操作步骤下面以dev名称为lex为分支名为例来操作一遍客户端操作:...

2023-10-07 12:14 guanshanw

Git 进阶(合并与变基)
Git 进阶(合并与变基)

在Git中整合来自不同分支的修改主要有两种方法:合并(merge)以及变基(rebase)合并(merge)merge流程图merge的原理是找到这两个分...

2023-10-07 12:13 guanshanw

Git学习笔记 003 Git进阶功能 part5 合并(第一部分)

合并(merge)是很常用的操作。尤其是一个庞大的很多人参与开发的企业级应用。一般会设定一个主分支,和多个副分支。在副分支开发完成后,合并到主分支中。始终保持主分支是一个完整的,稳定的最新状态的分支。...

非标题党,三张图帮你理解git merge和git rebase的区别
非标题党,三张图帮你理解git merge和git rebase的区别

初始场景:基于正常的开发分支修改几个小bug,然后在合并到开发分支上。gitmergegitcheckoutfeaturegitmergeho...

2023-10-07 12:13 guanshanw

git 初次使用(01)
git 初次使用(01)

先从github上克隆代码下来:使用vscode克隆代码如下图,填写上github仓库地址:vscode有时候克隆代码速度比较慢,可以用命令行方式克隆gitc...

2023-10-07 12:12 guanshanw

Git 远程操作

4.Git远程操作命令说明gitremote远程版本库操作gitfetch从远程获取版本库gitpull下载远程代码并合并gitpush上传远程代码并合并4.1远程版本库操作gitre...

Git常用命令-总结
Git常用命令-总结

创建git用户$gitconfig--globaluser.name"YourName"$gitconfig--globaluser.em...

2023-10-07 12:12 guanshanw

git中删除从别人clone下来项目的git信息,并修改为自己的分支

如果你从别人的Git存储库中克隆了一个项目,并想要删除与该存储库相关的Git信息,并将其修改为你自己的分支,则可以执行以下步骤:使用gitclone命令克隆存储库:gitclone<u...

git系列-回滚和放弃本地修改

回滚历史提交就是reset的功能。这种情况是已经提交远程仓库,需要回滚到之前的提交。gitreset--hardcommitId//注:强制提交后,当前版本后面的提交版本将会删掉!gi...

GIT使用小技巧大全
GIT使用小技巧大全

在大型软件工程的开发过程中,版本控制是无法绕过去的;目前来说,最火的版本控制软件就是GIT了。早两年SVN比较火,不过被大神linus喷了几次后,就日落西山了,...

2023-10-07 12:11 guanshanw

git相关命令-上
git相关命令-上

这些命令都是看了文档后,个人觉得比较有用的一些,展示给大家。回到远程仓库的状态抛弃本地所有的修改,回到远程仓库的状态。gitfetch--all&...

2023-10-07 12:10 guanshanw

Git命令行接口:掌握Git的必备技能
Git命令行接口:掌握Git的必备技能

Git是一款强大的分布式版本控制工具,它支持命令行界面操作。熟练掌握Git命令行接口,是开发者使用Git的必备技能之一。在这篇文章中,我们将介绍Git命令行接口...

2023-10-07 12:10 guanshanw

Git命令详解
Git命令详解

相信各位小伙伴们应该都对git有一些了解,毕竟作为代码管理的神器,就算不是IT行业的小伙伴肯定也或多或少的听说过一些。今天就来和小伙伴们分享一下自己总结的常用命...

2023-10-07 12:10 guanshanw

工作7年收集到的git命令
工作7年收集到的git命令

概念git中的术语解释:仓库也叫版本库(repository)stage:暂存区,add后会存到暂存区,commit后提交到版本库git安装linux...

2023-10-07 12:10 guanshanw

取消回复欢迎 发表评论: