前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【linux命令讲解大全】007.现代技术中的差异比较工具——diff

【linux命令讲解大全】007.现代技术中的差异比较工具——diff

作者头像
全栈若城
发布2024-03-02 11:23:17
1780
发布2024-03-02 11:23:17
举报
文章被收录于专栏:若城技术专栏若城技术专栏

diff

比较给定的两个文件的不同

补充说明

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

语法

diff (选项) (参数)

选项

-<行数>:指定要显示多少行的文本。此参数必须与 -c-u 参数一并使用。 --a--textdiff 预设只会逐行比较文本文件。 --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 参数时,仅显示不同之处。

参数

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

实例

以正常模式比较差异
代码语言:javascript
复制
diff a.txt b.txt

以上下文 (context) 模式比较差异

代码语言:javascript
复制
diff -c a.txt b.txt
代码语言:javascript
复制
*** a1.txt 2012-08-29 16:45:41.000000000 +0800
--- a2.txt 2012-08-29 16:45:51.000000000 +0800
***************
*** 1,7 ****
  a
  a
  a
! a
  a
  a
  a
--- 1,7 ----
  a
  a
  a
! b
  a
  a
  a

以联合 (unified) 模式比较差异

代码语言:javascript
复制
diff -u a.txt b.txt
代码语言:javascript
复制
--- a.txt 2012-08-29 16:45:41.000000000 +0800
+++ b.txt 2012-08-29 16:45:51.000000000 +0800
@@ -1,7 +1,7 @@
  a
  a
  a
- a
+ b
  a
  a
  a

多文件比较差异

将目录 /usr/li 下的文件 “test.txt” 与当前目录下的文件 “test.txt” 进行比较,输入如下命令:

代码语言:javascript
复制
diff /usr/li test.txt     #使用diff指令对文件进行比较

上面的命令执行后,会将比较后的不同之处以指定的形式列出,如下所示:

代码语言:javascript
复制
n1 a n3,n4  
n1,n2 d n3  
n1,n2 c n3,n4 

其中,字母 “a”、“d”、“c” 分别表示添加、删除及修改操作。而 “n1”、“n2” 表示在文件1中的行号,“n3”、“n4” 表示在文件2中的行号。

注意:以上说明指定了两个文件中不同处的行号及其相应的操作。在输出形式中,每一行后面将跟随受到影响的若干行。其中,以 < 开始的行属于文件1,以 > 开始的行属于文件2。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2024-02-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • diff
    • 补充说明
      • 语法
        • 选项
          • 参数
            • 实例
              • 以正常模式比较差异
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档