开发者社区> 云栖希望。> 正文

vim vimdiff diff 使用及命令

简介:
+关注继续查看

vim:

vim 从 vim7 开始加入了多标签切换的功能, 相当于多窗口. 之前的版本虽然也有多文件编辑功能, 但是总之不如这个方便啦。用法:
:tabnew [++opt选项] 〔+cmd〕 文件            建立对指定文件新的tab
:tabc       关闭当前的tab
:tabo       关闭所有其他的tab
:tabs       查看所有打开的tab
:tabp      前一个
:tabn      后一个
标准模式下:
gt , gT 可以直接在tab之间切换。
还有很多他命令, 看官大人自己, :help table 吧。

 

多窗口创建及焦点切换:

在Vim中开多窗口其实比较简单,也有不只一种方法,直接使用命令:new默认就是打开一个水平分割的新窗口。另外一个命令就是:split(sp)

但是默认水平分割多少有点不爽,因为本来屏幕就是宽屏的,代码几乎不会写那么长了,而真正缺少的垂直空间,所以这个时候就要用到垂直分割了,命令是:vsplit(vs),很简单了一目了然。

打开了这么多窗口不知道如何切换肯定不行啦。切换也很简单,组合键ctrl+w,然后通过j/k,来定位窗口,注意看好窗口光标变化。不过个人感觉这样比较麻烦,每切换一次窗口都要先按组合键才行。还好还有另一种方法,那就是直接连续按两次ctrl+w组合键,vim会自动跳到下一个窗口。

另外更改窗口宽度的命令是: Crtl+w > 将当前窗口向右边扩展一行,将 > 换成 < 就是向左边扩展一行。也可以在之前使用数字代表扩展的行数, 5 Ctrl+w > ,向右边扩展5行。

更改窗口高度类似,只是命令是Ctrl+w + ,增加高度,- 减小高度。

 

 

vimdiff:

 

启动vimdiff

方法一:# vimdiff  FILE_LEFT  FILE_RIGHT

方法二:# vim -d  FILE_LEFT  FILE_RIGHT

方法三:# vim FILE_LEFT 之后打开vim后输入:vertical diffsplit FILE_RIGHT

 

窗口布局切换

Ctrl-w K(把当前窗口移到最上边)

Ctrl-w H(把当前窗口移到最左边)

Ctrl-w J(把当前窗口移到最下边)

Ctrl-w L(把当前窗口移到最右边)

窗口焦点切换,即切换当前窗口

CTRL-w h 跳转到左边的窗口

CTRL-w j 跳转到下面的窗口

CTRL-w k 跳转到上面的窗口

CTRL-w l 跳转到右边的窗口

CTRL-w t 跳转到最顶上的窗口

CTRL-w b 跳转到最底下的窗口

CTRL-w w 跳转到另一个窗口

CTRL-w CTRL-w 跳转到另一个窗口,同CTRL-w w

光标移动

移动光标,切分窗口会同步移动,使用:set noscrollbind命令可取消同步

]c 跳到下一个不同的地方

[c 跳到上一个不同的地方

上下文折叠

默认情况下,vimdiff会将文件中不同之处上下6行之外的相同文本折叠隐藏,可通过 :set diffopt=context:3 修改显示的上下文行数。

zo 打开折叠

zc 关闭折叠

其他折叠

    zf   创建折叠(使用数字表示创建有当前行到下多少行的折叠,比如3j就创建包括4行的折叠)
    zo   打开折叠(l也可以打开折叠)
    zc   关闭当前折叠
    zm   关闭所有折叠
    zr   打开所有折叠
    zE   删除所有折叠
    zd   删除当前折叠
    za   若当前打开则关闭,若当前关闭则打开
    zj   到下一折叠的开始处
    zk   到上一折叠的末尾

文件合并

dp 将当前窗口光标位置处的内容复制到另一窗口

do 将另一窗口光标位置处的内容复制到当前窗口

diffupdate 重新比较两个文件,如果手动修改文件的话有时不会自动同步

文件操作

yy 复制当前行

nyy 复制当前行开始的n行

dd 删除当前行

ndd 删除当前行开始的n行

p 粘贴

u 撤销

CTRL-r 重复(即取消撤销)

wa 全部保存

wqa 全部保存后退出

qa 全部退出

qa! 全部强制退出,不保存文件修改

 

diff:

diff [option] file1 file2

 

下边是diff出来的结果:表示file1与file2的从60到63之间4行的比较结果!!

 

60,63c60,63

< ^[[00;34m malloc|^[[0m      45953       55944474              0^[[00;00m

< ^[[00;34mrealloc|^[[0m       5921         241437              0^[[00;00m   (in place: 1363, dec: 52)

< ^[[00;34m calloc|^[[0m       2171         323352              0^[[00;00m

< ^[[00;34m   free|^[[0m      54747       55682454

---

> ^[[00;34m malloc|^[[0m      47899       55961673              0^[[00;00m

> ^[[00;34mrealloc|^[[0m       8551         283037              0^[[00;00m   (in place: 1411, dec: 52)

> ^[[00;34m calloc|^[[0m       2433         341968              0^[[00;00m

> ^[[00;34m   free|^[[0m      58869       55759829

 

 

下边是diff添加选项-crN出来的结果:只发生+或-操作合并显示;发生修改则分开显示!!

*** 37,42 ****
--- 37,43 ----
  #define ENABLE_TOUCH_EVENTS @ENABLE_TOUCH_EVENTS_VALUE@
  #define ENABLE_VIDEO @ENABLE_VIDEO_VALUE@
  #define ENABLE_WEB_SOCKETS @ENABLE_WEB_SOCKETS_VALUE@
+ #define ENABLE_WML @ENABLE_WML_VALUE@
  #define ENABLE_WORKERS @ENABLE_WORKERS_VALUE@
  #define ENABLE_XHTMLMP @ENABLE_XHTMLMP_VALUE@
  #define ENABLE_XPATH @ENABLE_XPATH_VALUE@

 

*** 126,130 ****
          ENDIF ()
      ENDFOREACH ()

!     SOURCE_GROUP("DerivedSources" REGULAR_EXPRESSION "${DERIVED_SOURCES_WEBCORE_DIR}")
  ENDMACRO ()
--- 126,130 ----
          ENDIF ()
      ENDFOREACH ()

!     SOURCE_GROUP("DerivedSources" REGULAR_EXPRESSION "${DERIVED_SOURCES_DIR}")
  ENDMACRO ()

下边是diff添加选项-uarN出来的结果:从file1的第1225行开始的7行之内有删除,从file2的第1159行开始的6行之内有添加或修改!!

@@ -1225,7 +1159,6 @@
  XPATH support                                            : $enable_xpath
  XSLT support                                             : $enable_xslt
  Spellcheck support                                       : $enable_spellcheck
- Animation API                                            : $enable_animation_api

 GTK+ configuration:
  GTK+ version                                             : $with_gtk
diff -uarN r85406/GNUmakefile.am r82327/GNUmakefile.am
--- r85406/GNUmakefile.am   2011-06-20 13:27:54.000000000 +0800
+++ r82327/GNUmakefile.am   2011-06-20 10:23:56.000000000 +0800

本文转自博客园知识天地的博客,原文链接:vim vimdiff diff 使用及命令,如需转载请自行联系原博主。

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
vi/vim 基本使用方法
vi/vim 基本使用方法本文介绍了vi (vim)的基本使用方法,但对于普通用户来说基本上够了!vi编辑器是所有Unix及Linux系统下标准的编辑器,它的强大不逊色于任何最新的文本编辑器,这里只是简单地介绍一下它的用法和一小部分指令。
654 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
29126 0
vim 个人使用笔记
首先链接个网址,以后有什么快捷键没有使用过再查询吧 在vim中快速复制粘贴多行 用vim写代码时,经常遇到这样的场景,复制多行,然后粘贴。
691 0
Android开发教程 - 使用Data Binding Android Studio不能正常生成相关类/方法的解决办法
本系列目录 使用Data Binding(一)介绍 使用Data Binding(二)集成与配置 使用Data Binding(三)在Activity中的使用 使用Data Binding(四)在Fragment中的使用 ...
1084 0
vim的简单使用以及一些常用的命令
对于第一次用vi,有几点注意要提醒一下:1、用vi打开文件后,是处于「命令行模式(command mode)」,您要切换到「插入模式(Insert mode)」才能够输入文字。切换方法:在「命令行模式(command mode)」下按一下字母「i」就可以进入「插入模式(Insert mode)」,这时候你就可以开始输入文字了。
764 0
C#Winform使用扩展方法自定义富文本框(RichTextBox)字体颜色
在利用C#开发Winform应用程序的时候,我们有可能使用RichTextBox来实现实时显示应用程序日志的功能,日志又分为:一般消息,警告提示 和错误等类别。为了更好地区分不同类型的日志,我们需要使用不同的颜色来输出对应的日志,比如:一般消息为绿色,警告提示的用橙色,错误的用红色字体。
1414 0
阿里云服务器端口号设置
阿里云服务器初级使用者可能面临的问题之一. 使用tomcat或者其他服务器软件设置端口号后,比如 一些不是默认的, mysql的 3306, mssql的1433,有时候打不开网页, 原因是没有在ecs安全组去设置这个端口号. 解决: 点击ecs下网络和安全下的安全组 在弹出的安全组中,如果没有就新建安全组,然后点击配置规则 最后如上图点击添加...或快速创建.   have fun!  将编程看作是一门艺术,而不单单是个技术。
20688 0
+关注
云栖希望。
我是个随便的人
761
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
性能优化方法论
立即下载
手把手学习日志服务SLS,云启实验室实战指南
立即下载