Linux教程 | Linux 'Vimdiff' 命令 – 如何在命令行中比较两个文件

boyanx6个月前技术教程34

软件开发和维护有时会变得复杂。您可能会发现自己在比较代码或配置更改。

当您手动比较它们时,您可能会犯错误,并且很容易错过微小的更改。除此之外,在大文件中查找更改可能会令人筋疲力尽。

有许多在线工具和文本编辑器可以帮助您有效地比较文件。但是有一种更简单,更轻松的方法可以使用Linux命令行比较文件。

Linux命令行非常强大,并在其中提供了一个文件比较实用程序来并排区分文件。vim

在命令行中学习文件比较很有帮助,因为许多服务器仅使用 CLI(命令行界面)。这意味着您没有可以运行浏览器或其他文本编辑器的GUI。

什么是 vimdiff?

Vimdiff是一个 Linux 命令,可以编辑文件的两个、三个或四个版本,并显示它们的差异。Vim

Vimdiff语法

为了比较两个文件,语法如下:

 vimdiff [options] file1 file2

让我们比较两个文件并查看它们的差异。index.jsindex.js.bkp

vimdiff index.js index.js.bkp 

输出:

Vimdiff输出

在这里,我们可以看到突出显示的行中的差异。

为了使事情变得更容易,我们还可以显示行号。当您处于 中时,通过按两次转义并键入 进入扩展命令模式。这将显示当前会话的行号。Vim:set number

行号vim

让我们再次仔细看看输出:

的详细输出。vimdiff

  • 未折叠的行: 这些是尚未更改的代码行。这些是包装的,可以使用 和 键的组合来解开。z+cz+o
  • 突出显示的更改: 这些是文件中存在的差异。
  • 行号:这些是文件中相应的行号。
  • 文件名:左侧的文件名是命令中提到的第一个文件名。右侧的文件名是命令中提供的第二个文件名。

默认情况下,还有一种方法可以在Vim中启用行号,因此您不必每次都手动设置它。

如何在 Linux 上的 Vim 中默认显示行号

如果要在 中默认查看行号,可以按照以下步骤操作:Vim

  1. 找到该文件。vimrc

Vim配置存在于文件中。文件位置可能因 Linux 发行版而异。在 Ubuntu 中,该文件位于
.vimrcvimrc/usr/share/vim/

2. 编辑文件。vimrc

只需附加在文件中,然后保存并退出即可。set number

现在,每当您打开时,默认情况下都会有行号。Vim

Vimdiff操作

让我们看看如何利用 .vimdiff

首先,确保您处于命令模式。

您可以通过按两次键进入命令模式。escape

如何水平拆分屏幕

默认情况下,垂直拆分屏幕。如果您喜欢看到文件水平拆分,则可以像这样使用标志:vimdiff-o

vimdiff -o index.js index.js.bkp

输出:

水平拆分

如何在差异窗口中导航

  • 在差异窗口之间导航

要在窗格之间导航,请使用 的组合键。按下键后,光标将在文件之间切换。Ctrl+W+W

  • 跳转到更改

您可以使用特定的组合键跳转到更改,而不是逐行向下滚动并扫描更改。

  1. 要移动到上一个更改,请使用:。[ + c
  2. 要移动到上一个更改,请使用:] + c

如何从差异窗口应用更改

  • 要将更改从左侧文件应用到右侧文件:

要将更改从左侧文件应用到右侧文件,请首先移动到突出显示的更改。然后,使用以下命令:

:diffput

请记住,您需要处于命令模式。

用于从左到右应用更改。diffput

  • 要将更改从右侧文件应用到左侧文件:

要将更改从右侧文件应用到左侧文件,请首先移动到突出显示的更改。然后,使用以下命令:

:diffget

用于从右到左应用更改。diffget

如何撤消更改

如果您犯了错误,可以撤消更改,前提是您没有保存文件。

处于命令模式时,按键可撤消上次更改。u

如果您最近撤消了更改,则无法像以前那样看到突出显示的更改。您需要刷新才能再次看到更改。您可以使用以下命令执行此操作:

:diffupdate

如何打开和关闭折叠

未更改的行被换行以提供更好的可读性。

要按上述方式查看未折叠的行,请将光标移动到此处并使用以下组合键:

  • 要打开折叠:。z + o
  • 要关闭折叠:。z + c

如何退出差异窗口

根据最终结果,有许多方法可以退出差异窗口。

  • :qa退出所有文件而不保存。
  • :q逐个退出文件而不保存。
  • :wq!逐个保存和退出文件。

结论

比较文件既简单又快速,因为我们在命令行中比较文件。在本教程中,您学习了如何使用该命令有效地查找代码或配置文件中的差异。

相关文章

linux中如何比较两个文件的异同?

有一个diff的命令可以达到这个目的。常用参数:" -b " 忽略空格" -B " 忽略空行" -i " 忽略大小写" -c " 显示文...

深度解析丨文件智能比对(OCR),只盖审批通过的文件

章管家文件智能比对(OCR)功能,是帮助印章管理人员大幅提高审核效率的新功能。下面带你一次性了解最全面的文件智能比对!文件智能比对,是运用人工智能技术,将用印前、后的文件与审批通过的源文件进行智能比对...

的863kb小工具,解除重复文件烦恼,办公族、资源帝的福音

你的电脑上有重复文件吗?就是那种同一个文件,不小心存储了好几份的情况。对于像我这样经常需要坐电脑前的苦比来说,经常是找到一个资源,就赶紧下载下来。有时候害怕不保险,还要优盘里存一份,或者再给移动硬盘里...

小科普 | 文件恢复哪家强?5个软件横向对比

数据丢了怎么办?哪家恢复软件最好使?找了一圈发现只有单一软件的教程,很少有人对比测试,万一我们哪天真碰上的掉数据的事儿,该用什么软件修复呢?今天我们就来寻找这个答案。对比挑了最常见、口碑较好的5个软件...

CAD中图纸比较功能怎么用

今天来说用CAD梦想画图中图纸比较功能怎么使用。操作工具操作系统:Windows10CAD软件:CAD梦想画图步骤1.首先打开原图纸后点击功能菜单下的高级工具,如下图所示:高级工具2.接着会弹出高级工...

新文件格式公布 CASC格式优势对比与介绍

在今天的暗黑3新补丁前瞻博文中,暴雪介绍下个补丁中暗黑3的文件格式将全面转向一种新格式 - CASC,面对老朋友MPQ格式文件,很多暗黑玩家也许对这种文件格式感到陌生,但其实从《风暴英雄》和《魔兽世界...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。