diff 命令详解

| 选择喜欢的代码风格  

A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

diff 命令安装:


-bash/zsh: diff command not found

#Debian
apt-get install diffutils

#Ubuntu
apt-get install diffutils

#Alpine
apk add diffutils

#Arch Linux
pacman -S diffutils

#Kali Linux
apt-get install diffutils

#CentOS
yum install diffutils

#Fedora
dnf install diffutils

#OS X
brew install diffutils

#Raspbian
apt-get install diffutils

#Docker
docker run cmd.cat/diff diff

diff 命令补充说明:


diff 命令在最简单的情况下,比较给定的两个文件的不同。如果使用 - 代替 “文件” 参数,则要比较的内容将来自标准输入。diff 命令是以逐行的方式,比较文本文件的异同处。如果该命令指定进行目录的比较,则将会比较该目录中具有相同文件名的文件,而不会对其子目录文件进行任何比较操作。

diff 实际上并不更改它比较的文件。 但是,它可以选择为程序 edex 生成脚本(如果指定了 -e 选项),该脚本可用于应用更改。

diff 命令语法:


diff [OPTION]... FILES

diff 命令选项:


-<行数>:指定要显示多少行的文本。此参数必须与-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参数时,仅显示不同之处。

diff 命令参数:


文件1:指定要比较的第一个文件;
文件2:指定要比较的第二个文件。

diff 命令实例


$ diff file1.txt file2.txt

2,4c2,4
< I need to run the laundry.
< I need to wash the dog.
< I need to get the car detailed.
---
> I need to do the laundry.
> I need to wash the car.
> I need to get the dog detailed.

第一个文件对应的行号,
字母(a表示添加,c表示更改,d表示删除),以及
与第二个文件相对应的行号。

在上面的输出中,“ 2,4c2,4”表示:“第一个文件中的第2至4行需要更改以匹配第二个文件中的第2至4行。” 
然后告诉我们每个文件中的那些行:

以<开头的行是第一个文件中的行;
以>开头的行是第二个文件中的行。
$ diff -c file1.txt file2.txt
*** file1.txt   2014-08-21 17:58:29.764656635 -0400
--- file2.txt   2014-08-21 17:58:50.768989841 -0400
***************
*** 1,4 ****
  apples
- oranges
  kiwis
  carrots
--- 1,4 ----
  apples
  kiwis
  carrots
+ grapefruits

此输出的前两行向我们显示有关“从”文件(文件1)和“至”文件(文件 2)的信息。 
它列出了每个文件的文件名,修改日期和修改时间,每行一个。 from 文件由 *** 指示,to 文件由 --- 指示。

下一行具有三个星号(***),后跟第一个文件的行范围(在本例中为第 1 至 4 行,用逗号分隔)。 然后是四个星号(****)。
然后,它向我们显示了这些行的内容。 如果该行未更改,则以两个空格作为前缀。 
但是,如果更改了该行,则会在其前面加上指示性字符和空格。 

diff 比对字符含义如下:

字符 含义
! 表示此行是一个或多个需要更改的行的一部分。 有一组以 ! 为前缀的行。 在另一个文件的上下文中也是如此。
+ 指示第二个文件中需要添加到第一个文件中的一行。
- 指示第一个文件中需要删除的一行。

在第一个文件的行之后,有三个破折号(---),然后是行范围,然后是四个破折号(----)。 这表明第二个文件中的行范围将与第一个文件中的更改同步。

如果需要更改的部分不止一个,diff 将逐个显示这些部分。 第一个文件中的行仍将以 *** 表示,第二个文件中的行仍将以 --- 表示。

diff 比较文件:

diff file1 file2

diff 比较文件,忽略空格:

diff -w file1 file2

diff 比较文件,并排显示差异:

diff -y file1 file2

diff 比较文件,以统一格式(由git diff`使用)显示差异:

diff -u file1 file2

diff 递归比较目录:

diff -r directory1 directory2

diff 比较目录,仅显示不同的文件名:

diff -rq directory1 directory2

diff 命令扩展阅读:




diff 命令评论