良许Linux教程网 干货合集 Linux系统diff命令详解

Linux系统diff命令详解

Linux系统中diff命令主要用于比较文件差异,执行命令之后可以打印出文件之间的差异。它可以逐行地比较两个文件的内容,也可以递归地比较文件夹的内容,下面良许教程网为大家分享一下Linux系统diff命令的具体使用方法。

Linux系统diff命令详解

语法

 diff [-abBcdefHilnNpPqrstTuvwy][-][-C ][-D ][-I ][-S ][-W ][-x ][-X ][--help][--left-column][--suppress-common-line][文件或目录1][文件或目录2]

参数:

-  指定要显示多少行的文本。此参数必须与-c或-u参数一并使用。

-a或–text  diff预设只会逐行比较文本文件。

-b或–ignore-space-change  不检查空格字符的不同。

  • -B或–ignore-blank-lines  不检查空白行。

  • -c  显示全部内文,并标出不同之处。

  • -C或–context  与执行”-c-”指令相同。

  • -d或–minimal  使用不同的演算法,以较小的单位来做比较。

  • -D或ifdef  此参数的输出格式可用于前置处理器巨集。

  • -e或–ed  此参数的输出格式可用于ed的script文件。

  • -f或-forward-ed  输出的格式类似ed的script文件,但按照原来文件的顺序来显示不同处。

  • -H或–speed-large-files  比较大文件时,可加快速度。

  • -l或–ignore-matching-lines  若两个文件在某几行有所不同,而这几行同时都包含了选项中指定的字符或字符串,则不显示这两个文件的差异。

  • -i或–ignore-case  不检查大小写的不同。

  • -l或–paginate  将结果交由pr程序来分页。

  • -n或–rcs  将比较结果以RCS的格式来显示。

  • -N或–new-file  在比较目录时,若文件A仅出现在某个目录中,预设会显示:

  • Only in目录:文件A若使用-N参数,则diff会将文件A与一个空白的文件比较。

  • -p  若比较的文件为C语言的程序码文件时,显示差异所在的函数名称。

  • -P或–unidirectional-new-file  与-N类似,但只有当第二个目录包含了一个第一个目录所没有的文件时,才会将这个文件与空白的文件做比较。

  • -q或–brief  仅显示有无差异,不显示详细的信息。

  • -r或–recursive  比较子目录中的文件。

  • -s或–report-identical-files  若没有发现任何差异,仍然显示信息。

  • -S或–starting-file  在比较目录时,从指定的文件开始比较。

  • -t或–expand-tabs  在输出时,将tab字符展开。

  • -T或–initial-tab  在每行前面加上tab字符以便对齐。

  • -u,-U或–unified=  以合并的方式来显示文件内容的不同。

  • -v或–version  显示版本信息。

  • -w或–ignore-all-space  忽略全部的空格字符。

  • -W或–width  在使用-y参数时,指定栏宽。

  • -x或–exclude  不比较选项中所指定的文件或目录。

  • -X或–exclude-from  您可以将文件或目录类型存成文本文件,然后在=中指定此文本文件。

  • -y或–side-by-side  以并列的方式显示文件的异同之处。

  • –help  显示帮助。

  • –left-column  在使用-y参数时,若两个文件某一行内容相同,则仅在左侧的栏位显示该行内容。

  • –suppress-common-lines  在使用-y参数时,仅显示不同之处。

案例演示:

假设我们有两个文件(file1 和 file2):

 $ cat file1
 Hi,
 Hello,
 How are you?
 I am fine,
 Thank you.
 
 
 $ cat file2
 Hello,
 Hi,
 How are you?
 I am fine.

你可以看见两个文件有些小的不同。现在,让我们看看diff命令如何找出两者的不同的。

像这样运行diff命令:

 $ diff file1 file2
 1d0
  Hi,
 4,5c4
  I am fine.

你可以看见diff后面跟了两个文件的名字作为命令行的参数,并且它在输出中生成了差异比较。输出并不容易理解。理由是,这是被计算机使用的而不是为了人类。尽管如此,让我们一步步解码输出:

注意 – 在下面的文本中,file1和file2将被当作旧文件和新文件。

 1d0
 

这里,1d0这一行意味着旧文件的第一行应该被删除(d)以使两个文件的第一行同步。旧文件中需要被删除的行以'

 2a2
 > Hi,

这里,2a2行意味着新文件中的第二行应该加到旧文件的第二行后。要添加的行显示在输出的下一行用’>’标记。

 4,5c4
  I am fine.

这里,4,5c4这一行意味着在旧文件中的4到5行现在已被改变并且需要用新文件中的第4行代替。添加和删除的行分别用’>’和'

那么,来总结一下,

  • 首先diff命令的第一个参数被视为旧文件而第二个参数被视为新文件。

  • 像1d0、2a2、4,5c4这种表达式可以用语法解码为 旧文件的行号或者行的范围[新文件的行号或者行的范围]。这里的’行为’可以是追加,删除或者改变替换。

  • ‘’代表添加的行。

除了文件外,diff命令还可以比较两个目录。让我们通过一个例子学习。

这里是’new_dir’目录包含的内容:

 $ ls new_dir/
 file file2 frnd frnd1.cpp log1.txt log3.txt log5.txt
 file1 file name with spaces frnd1 frnd.cpp log2.txt log4.txt

这是’origdir’目录含有的内容:(译注:原文为and here are the contents of a directory named ‘olddir’ ,其中’old_dir’应为笔误。)

 $ ls orig_dir/
 file1 file name with spaces frnd1 frnd.cpp log2.txt log4.txt test
 file2 frnd frnd1.cpp log1.txt log3.txt log5.txt

下面是diff命令执行后的输出:

 $ diff new_dir/ orig_dir/
 Only in new_dir/: file
 Only in orig_dir/: test

你可以看到当diff命令被用来比较这两个目录时,很容易就会显示两个文件中缺失的文件。

下面是一些在命令行下常用的选项:

1. 用 -i 忽略大小写

如果两个文件含有相同的文本但是大小写不同,diff命令仍会默认报告它不同。

比如:

 $ cat file1
 HI
 
 $ cat file2
 hi
 
 $ diff file1 file2
 1c1
  hi

你可以看见diff命令在输出中报告了大小写不同。

要去除这个默认行为,使用-i选项。

以下是个例子:

 $ diff -i file1 file2
 $

这样你可以看到没有生成输出,这是当两个文件相同时的默认行为。

2. 用 -s 选项报告两个文件相同

在例子1的后面,我们看到如果文件相同diff不会生成报告。虽然这个默认行为不错但是它仍可能会造成很大疑惑,特别对于新手而言。因此,如果你像样diff命令明确地报告两个文件不同,那么就使用-s命令选项。

来举个例子:

 $ diff -is file1 file2
 Files file1 and file2 are identical

你可以看到我加了-s选项在后面的例子中,这次diff命令会明确地报告两个文件是相同的。

3. 使用 -b 忽略空格

另外一个常用的是diff报告文件存在不同数量的空格。

举例说明:

 $ cat file1
 Hi, how are you?
 
 $ cat file2
 Hi, how are  you?

观察这两个文件唯一的不同是file2中’are’和’you’之间额外的空格。现在,当使用diff命令比较两个文件时,输出如下:

 $ diff file1 file2
 1c1
  Hi, how are  you?

因此你可以看到diff命令报告了不同。但是如果你想要忽略这些空格,使用 -b 选项。

 $ diff -b file1 file2
 $

这样你可以看到由于-b选项,diff命令报告这两个文件是相同的。

diff命令还提供了更多的命令行选项。阅读man page来获取完整的列表。

以上就是良许教程网为各位朋友分享的Linux系统相关内容。想要了解更多Linux相关知识记得关注公众号“良许Linux”,或扫描下方二维码进行关注,更多干货等着你!

137e00002230ad9f26e78-265x300

本文由 良许Linux教程网 发布,可自由转载、引用,但需署名作者且注明文章出处。如转载至微信公众号,请在文末添加作者公众号二维码。
良许

作者: 良许

良许,世界500强企业Linux开发工程师,公众号【良许Linux】的作者,全网拥有超30W粉丝。个人标签:创业者,CSDN学院讲师,副业达人,流量玩家,摄影爱好者。
上一篇
下一篇

发表评论

电子邮件地址不会被公开。 必填项已用*标注

联系我们

联系我们

公众号:良许Linux

在线咨询: QQ交谈

邮箱: yychuyu@163.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部