转自:https://www.jianshu.com/p/5e359ac7d609
vimdiff 等同于 vim -d 命令,即 Vim 编辑器的 diff 模式。该命令后面通常会接两个或多个文件名作为参数,这些文件会同时在 Vim 编辑器的分割窗口中打开,并高亮显示文件中内容有差异的部分。同时该模式下还提供部分快捷按键用于完成文件内容的合并等操作。
vimdiff
命令常用于编辑同一文件的不同历史版本,对各文件的内容进行比对与调整。如下面两个文件:
$ cat file1 Line one Line 2 Line three Line 4 Line 5 Line 6
$ cat file2 Line 1 Line 2 Line 3 Line 4 Line 5 Line 6 Line 7 Line 8
可以使用
vim -O2 file1 file2
命令,在左右排列的两个窗口中同时打开 file1 和 file2 两个文件,如下图所示:
而
vimdiff file1 file2
命令会以同样的形式打开这两个文件,并且用不同的背景色高亮显示彼此间有差别的内容,如下图:
从上面的两幅截图中可以得出 vimdiff 标记差别内容时的几个规则:
除了 vimdiff FILE_LEFT FILE_RIGHT 或者 vim -d FILE_LEFT FILE_RIGHT 的形式外,也可以通过在 vim 中输入命令进入 diff 模式。
比如先进入 vim 编辑 FILE_LEFT 文件(vim FILE_LEFT),再输入以下命令进入 diff 模式:
:vertical diffsplit FILE_RIGHT
可以使用下列两种快捷键,在文件的各个差异点之间前后移动:
至于光标在两个窗口之前的切换,可以使用如下按键:
可以使用 d, p (即 diff put)命令,将当前差异点中的内容覆盖到另一文件中的对应位置。 如当光标位于左侧文件(file1)中的第一行时,依次按下 d、p 键,则 file1 中的 Line one 被推送到右侧,并替换掉 file2 中对应位置上的 Line 1 。截图如下:
可与上一幅截图对比查看效果。
而 d, o(即 diff obtain)命令可以将另一窗口中差异点处的内容拉取到当前位置并进行替换操作。截图如下:
即在 file1 的第一行执行 d o 命令后,file2 中的第一行内容 Line 1 被拉取到 file1 中并替换掉原来位置上的 Line one。
vimdiff 实际上是 Vim 编辑器的 diff 模式,因此适用于 vim 编辑器的命令和快捷键也同样可以在该模式下使用。常用的几个命令如下:
:qa
:退出所有文件:wa
:保存所有文件:wqa
:保存并退出所有文件qa!
:强制退出(不保存)所有文件z o
:查看被折叠的内容z c
:重新折叠其他常用的命令与快捷键可参考 Vim 速查手册