shell命令--vimdiff

shell命令--vimdiff

0、vimdiff命令的专属图床

点此快速打开文章图床_shell命令vimdiff

1、vimdiff命令的功能说明

​ 纯文本文件比较和合并工具一直是软件开发过程中比较重要的组成部分,vimdiff 能够在比较出来的多处差异之间快速定位,很容易的进行文件合并操作。在需要快速比较和合并少量文件的时候,vimdiff 是很好的选择。首先保证系统中的 diff 命令是可用的。Vimdiff 模式是依赖于 diff 命令的。

2、vimdiff命令的语法格式

SYNOPSIS
    vimdiff [options] file1 file2 [file3 [file4]]

    gvimdiff

3、vimdiff命令的选项说明

vimdiff 选项不常用,此处省略。

4、vimdiff命令的实践操作

范例1:使用 vimdiff 比较 file1.txtfile2.txt

vimdiff file*

​ 打开图片我们可以看到一个清晰的比较结果。屏幕被垂直分割,左右两侧分别显示被比较的两个文件。两个文件中连续的相同的行被折叠了起来,以便使用者能把注意力集中在两个文件的差异上。只在某一文件中存在的行的背景色被设置为蓝色,而在另一文件中的对应位置被显示为绿色。两个文件中都存在,但是包含差异的行显示为粉色背景,引起差异的文字用红色背景加以突出。

​ 如果希望交换两个窗口的位置,或者希望改变窗口的分割方式,可以使用下列命令:

  1. Ctrl-w K(把当前窗口移到最上边)
  2. Ctrl-w H(把当前窗口移到最左边)
  3. Ctrl-w J(把当前窗口移到最下边)
  4. Ctrl-w L(把当前窗口移到最右边)其中1和3两个操作会把窗口改成水平分割方式。

光标移动

​ 接下来试试在行间移动光标,可以看到左右两侧的屏幕滚动是同步的。这是因为 scrollbind 选项被设置了的结果,vimdiff 会尽力保证两侧文件的对齐。如果不想要这个特性,可以设置:

:set noscrollbind

​ 可以使用快捷键在各个差异点之间快速移动。跳转到下一个差异点:

]c

​ 反向跳转是:

[c

​ 如果在命令前加上数字的话,可以跳过一个或数个差异点,从而实现跳的更远。比如如果在位于第一个差异点的行输入 2]c,将越过下一个差异点,跳转到第三个差异点。

文件合并

​ 文件比较的最终目的之一就是合并,以消除差异。如果希望把一个差异点中当前文件的内容复制到另一个文件里,可以使用命令:

dp (diff "put")

​ 如果希望把另一个文件的内容复制到当前行中,可以使用命令:

do (diff "get",之所以不用dg,是因为dg已经被另一个命令占用了)

​ 如果希望手工修改某一行,可以使用通常的 vimdiff 操作。如果希望在两个文件之间来回跳转,可以用下列命令序列:

Ctrl-w, w

​ 在修改一个或两个文件之后,vimdiff 会试图自动来重新比较文件,来实时反映比较结果。但是也会有处理失败的情况,这个时候需要手工来刷新比较结果:

:diffupdate

如果希望撤销修改,可以和平常用 vim 编辑一样,直接

<ESC>, u

同时操作两个文件

​ 在比较和合并告一段落之后,可以用下列命令对两个文件同时进行操作。比如同时退出:

:qa (quit all)

​ 如果希望保存全部文件:

:wa (write all)

​ 或者是两者的合并命令,保存全部文件,然后退出:

:wqa (write, then quit all)

​ 如果在退出的时候不希望保存任何操作的结果:

:qa! (force to quit all)

上下文的展开和查看

​ 比较和合并文件的时候经常需要结合上下文来确定最终要采取的操作。Vimdiff 缺省是会把不同之处上下各 6 行的文本都显示出来以供参考。其他的相同的文本行被自动折叠。如果希望修改缺省的上下文行数,可以这样设置:

:set diffopt=context:3

​ 可以用简单的折叠命令来临时展开被折叠的相同的文本行:

zo (folding open,之所以用z这个字母,是因为它看上去比较像折叠着的纸)

​ 然后可以用下列命令来重新折叠:

zc (folding close)

结论

​ 在无法使用图形化的比较工具的时候,或者在需要快速比较和合并少量文件的时候,vimdiff 是最好的选择。

『MineGi有话说』:快来扫一扫下面链接的二维码,加入我们吧!

posted @ 2020-01-26 08:00  MineGi  阅读(555)  评论(0编辑  收藏  举报