Linux diff 命令教程:轻松学会用diff 命令比较文件的差别(附巨量语法参数 ...

打印 上一主题 下一主题

主题 838|帖子 838|积分 2514

Linux diff 命令

Linux diff 命令用于比较文件的差别。
diff 以逐行的方式,比较文本文件的异同处。如果指定要比较目次,则 diff 会比较目次中相同文件名的文件,但不会比较其中子目次。
语法

  1. diff [-abBcdefHilnNpPqrstTuvwy][-<行数>][-C <行数>][-D <巨集名称>][-I <字符或字符串>][-S <文件>][-W <宽度>][-x <文件或目录>][-X <文件>][--help][--left-column][--suppress-common-line][文件或目录1][文件或目录2]
复制代码
参数

  1. -<行数>  指定要显示多少行的文本。此参数必须与-c或-u参数一并使用。
  2. -a或--text  diff预设只会逐行比较文本文件。
  3. -b或--ignore-space-change  不检查空格字符的不同。
  4. -B或--ignore-blank-lines  不检查空白行。
  5. -c  显示全部内文,并标出不同之处。
  6. -C<行数>或--context<行数>  与执行"-c-<行数>"指令相同。
  7. -d或--minimal  使用不同的演算法,以较小的单位来做比较。
  8. -D<巨集名称>或ifdef<巨集名称>  此参数的输出格式可用于前置处理器巨集。
  9. -e或--ed  此参数的输出格式可用于ed的script文件。
  10. -f或-forward-ed  输出的格式类似ed的script文件,但按照原来文件的顺序来显示不同处。
  11. -H或--speed-large-files  比较大文件时,可加快速度。
  12. -I<字符或字符串>或--ignore-matching-lines<字符或字符串>  若两个文件在某几行有所不同,而这几行同时都包含了选项中指定的字符或字符串,则不显示这两个文件的差异。
  13. -i或--ignore-case  不检查大小写的不同。
  14. -l或--paginate  将结果交由pr程序来分页。
  15. -n或--rcs  将比较结果以RCS的格式来显示。
  16. -N或--new-file  在比较目录时,若文件A仅出现在某个目录中,预设会显示:
  17. Only in目录:文件A若使用-N参数,则diff会将文件A与一个空白的文件比较。
  18. -p  若比较的文件为C语言的程序码文件时,显示差异所在的函数名称。
  19. -P或--unidirectional-new-file  与-N类似,但只有当第二个目录包含了一个第一个目录所没有的文件时,才会将这个文件与空白的文件做比较。
  20. -q或--brief  仅显示有无差异,不显示详细的信息。
  21. -r或--recursive  比较子目录中的文件。
  22. -s或--report-identical-files  若没有发现任何差异,仍然显示信息。
  23. -S<文件>或--starting-file<文件>  在比较目录时,从指定的文件开始比较。
  24. -t或--expand-tabs  在输出时,将tab字符展开。
  25. -T或--initial-tab  在每行前面加上tab字符以便对齐。
  26. -u,-U<列数>或--unified=<列数>  以合并的方式来显示文件内容的不同。
  27. -v或--version  显示版本信息。
  28. -w或--ignore-all-space  忽略全部的空格字符。
  29. -W<宽度>或--width<宽度>  在使用-y参数时,指定栏宽。
  30. -x<文件名或目录>或--exclude<文件名或目录>  不比较选项中所指定的文件或目录。
  31. -X<文件>或--exclude-from<文件>  您可以将文件或目录类型存成文本文件,然后在=<文件>中指定此文本文件。
  32. -y或--side-by-side  以并列的方式显示文件的异同之处。
  33. --help  显示帮助。
  34. --left-column  在使用-y参数时,若两个文件某一行内容相同,则仅在左侧的栏位显示该行内容。
  35. --suppress-common-lines  在使用-y参数时,仅显示不同之处。
复制代码
让我们通过一些实际的例子理解diff命令。

假设我们有两个文件(file1 和 file2):
  1. $ cat file1
  2. Hi,
  3. Hello,
  4. How are you?
  5. I am fine,
  6. Thank you.
  7. $ cat file2
  8. Hello,
  9. Hi,
  10. How are you?
  11. I am fine.
复制代码
你可以瞥见两个文件有些小的不同。现在,让我们看看diff命令如何找出两者的不同的。
像这样运行diff命令:
  1. $ diff file1 file2
  2. 1d0
  3. < Hi,
  4. 2a2
  5. > Hi,
  6. 4,5c4
  7. < I am fine,
  8. < Thank you.
  9. ---
  10. > I am fine.
复制代码
你可以瞥见diff后面跟了两个文件的名字作为命令行的参数,而且它在输出中天生了差别比较。输出并不容易理解。理由是,这是被盘算机使用的而不是为了人类。只管如此,让我们一步步解码输出:
  1. #注意 – 在下面的文本中,file1和file2将被当作旧文件和新文件。
  2. 1d0
  3. < Hi,
  4. #这里,1d0这一行意味着旧文件的第一行应该被删除(d)以使两个文件的第一行同步。旧文件中需要被删除的行以'<'标记。
  5. 2a2
  6. > Hi,
  7. #这里,2a2行意味着新文件中的第二行应该加到旧文件的第二行后。要添加的行显示在输出的下一行用'>'标记。
  8. 4,5c4
  9. < I am fine,
  10. < Thank you.
  11. ---
  12. > I am fine.
复制代码
这里,4,5c4这一行意味着在旧文件中的4到5行现在已被改变而且必要用新文件中的第4行取代。添加和删除的行分别用'>'和'<'表现。
那么,来总结一下,


  • 首先diff命令的第一个参数被视为旧文件而第二个参数被视为新文件。
  • 像1d0、2a2、4,5c4这种表达式可以用语法解码为 [旧文件的行号或者行的范围][举动][新文件的行号或者行的范围]。这里的'举动'可以是追加,删除或者改变替换。
  • '<'代表删除的行,而'>'代表添加的行。
除了文件外,diff命令还可以比较两个目次。让我们通过一个例子学习。
这里是'new_dir'目次包含的内容:
  1. $ ls new_dir/
  2. file file2 frnd frnd1.cpp log1.txt log3.txt log5.txt
  3. file1 file name with spaces frnd1 frnd.cpp log2.txt log4.txt
  4. #这是'origdir'目录含有的内容:(译注:原文为and here are the contents of a directory named ‘olddir’ ,其中'old_dir'应为笔误。)
  5. $ ls orig_dir/
  6. file1 file name with spaces frnd1 frnd.cpp log2.txt log4.txt test
  7. file2 frnd frnd1.cpp log1.txt log3.txt log5.txt
  8. #下面是diff命令执行后的输出:
  9. $ diff new_dir/ orig_dir/
  10. Only in new_dir/: file
  11. Only in orig_dir/: test
复制代码
你可以看到当diff命令被用来比较这两个目次时,很容易就会显示两个文件中缺失的文件。
下面是一些在命令行下常用的选项:
1. 用 -i 忽略巨细写

如果两个文件含有相同的文本但是巨细写不同,diff命令仍会默认报告它不同。
好比:
  1. $ cat file1
  2. HI
  3. $ cat file2
  4. hi
  5. $ diff file1 file2
  6. 1c1
  7. < HI
  8. ---
  9. > hi
  10. #你可以看见diff命令在输出中报告了大小写不同。
  11. #要去除这个默认行为,使用-i选项。
  12. #以下是个例子:
  13. $ diff -i file1 file2
  14. $
复制代码
这样你可以看到没有天生输出,这是当两个文件相同时的默认举动。
2. 用 -s 选项报告两个文件相同

在例子1的后面,我们看到如果文件相同diff不会天生报告。虽然这个默认举动不错但是它仍可能会造成很大疑惑,特别对于新手而言。因此,如果你像样diff命令明白地报告两个文件不同,那么就使用-s命令选项。
来举个例子:
  1. $ diff -is file1 file2
  2. Files file1 and file2 are identical
复制代码
你可以看到我加了-s选项在后面的例子中,这次diff命令会明白地报告两个文件是相同的。
3. 使用 -b 忽略空格

别的一个常用的是diff报告文件存在不同数量的空格。
举例阐明:
  1. $ cat file1
  2. Hi, how are you?
  3. $ cat file2
  4. Hi, how are  you?
复制代码
观察这两个文件唯一的不同是file2中'are'和'you'之间额外的空格。现在,当使用diff命令比较两个文件时,输出如下:
  1. $ diff file1 file2
  2. 1c1
  3. < Hi, how are you?
  4. ---
  5. > Hi, how are  you?
复制代码
因此你可以看到diff命令报告了不同。但是如果你想要忽略这些空格,使用 -b 选项。
  1. $ diff -b file1 file2
  2. $
复制代码
这样你可以看到由于-b选项,diff命令报告这两个文件是相同的。

阐明:



  • "|"表现前后2个文件内容有不同
  • "<"表现后面文件比前面文件少了1行内容
  • ">"表现后面文件比前面文件多了1行内容

这里是封面:


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

温锦文欧普厨电及净水器总代理

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表