LINUX DIFF命令

简介: diff命令本身很简单,需要注意的是要会阅读其输出。

diff命令本身很简单,需要注意的是要会阅读其输出。      


diff 的模式有三种

* 正常格式(normal diff)

* 上下文格式(context diff)

* 合并格式(unified diff)

一、正常模式


不带参数输出就是正常模式

11]# diff  /dfs/acf/INDEX/202010/10/A1350AOIL05.TXT /dfs/acf/INDEX/202010/11/A1350AOIL05.TXT |more
1,101494c1,26841
< 002538 \A1575A1BPK1\A10A9\A10A902R\A10A902RCH\FORMAT\A1350A10A902RCH.TXT
< 002538 \A1575A1BPK1\A10A9\A10A902R\A10A902RCH\GlassID\A1350A10A902RCH-Mark9.JPG
< 002538 \A1575A1BPK1\A10A9\A10A902R\A10A902RCH\GlassID\A1350A10A902RCH-Mark10.JPG
< 002538 \A1575A1BPK1\A10A9\A10A902R\A10A902RCH\GRAYIMAGE\A1350A10A902RCHDM.JPG
< 002538 \A1575A1BPK1\A10A9\A10A902R\A10A902RCH\GRAYIMAGE\A1350A10A902RCHFPIP000001.JPG

1,101494c1,26841


它分成三个部分:前面的"1,101494",表示f1的第1-101494行有变化;中间的"c"表示变动的模式是内容改变(change),其他模式还有"增加"(a,代表addition)和"删除"(d,代表deletion);后面的"1,26841",表示变动后变成f2的1,26841


  • <002538\A1575A1BPK1\A10A9\A10A902R\A10A902RCH\FORMAT\A1350A10A902RCH.TXT


前面的小于号,表示要从/dfs/acf/INDEX/202010/10/A1350AOIL05.TXT 当中去除该行(也就是1 - 101494),后面的是内容


  • > 013033 \A1575A1BPK1\A10AA\A10AA04W\A10AA04WCD\GRAYIMAGE\A1350A10AA04WCDDM.JPG


前面的大于号表示/dfs/acf/INDEX/202010/11/A1350AOIL05.TXT增加了该行,后面的表示该行的内容。


这个和正则中的环视有点像,可以对比理解。

二、上下文格式(context diff)


使用参数 c

11]# diff -c /dfs/acf/INDEX/202010/10/A1350AOIL05.TXT /dfs/acf/INDEX/202010/11/A1350AOIL05.TXT |more
*** /dfs/acf/INDEX/202010/10/A1350AOIL05.TXT  2020-10-10 23:59:37.108102000 +0800
--- /dfs/acf/INDEX/202010/11/A1350AOIL05.TXT  2020-10-11 03:13:37.984228000 +0800
***************
*** 1,101494 ****
! 002538 \A1575A1BPK1\A10A9\A10A902R\A10A902RCH\FORMAT\A1350A10A902RCH.TXT
! 002538 \A1575A1BPK1\A10A9\A10A902R\A10A902RCH\GlassID\A1350A10A902RCH-Mark9.JPG
! 002538 \A1575A1BPK1\A10A9\A10A902R\A10A902RCH\GlassID\A1350A10A902RCH-Mark10.JPG
! 002538 \A1575A1BPK1\A10A9\A10A902R\A10A902RCH\GRAYIMAGE\A1350A10A902RCHDM.JPG
! 002538 \A1575A1BPK1\A10A9\A10A902R\A10A902RCH\GRAYIMAGE\A1350A10A902RCHFPIP000001.JPG

第一部分的两行,显示两个文件的基本情况:文件名和时间信息。


*** /dfs/acf/INDEX/202010/10/A1350AOIL05.TXT    2020-10-10 23:59:37.108102000 +0800

--- /dfs/acf/INDEX/202010/11/A1350AOIL05.TXT    2020-10-11 03:13:37.984228000 +0800


"***"表示变动前的文件,"---"表示变动后的文件。

第二部分显示变动前的文件即10号的文件


*** 1,101494 ****

! 002538 \A1575A1BPK1\A10A9\A10A902R\A10A902RCH\FORMAT\A1350A10A902RCH.TXT

! 002538 \A1575A1BPK1\A10A9\A10A902R\A10A902RCH\GlassID\A1350A10A902RCH-Mark9.JPG

! 002538 \A1575A1BPK1\A10A9\A10A902R\A10A902RCH\GlassID\A1350A10A902RCH-Mark10.JPG

文件内容的每一行最前面有一个标记位。 如果为空,表示该行无变化 如果是感叹号(!),表示该行有改动 如果是减号(-),表示该行被删除 如果是加号(+),表示该行为新增。

三、合并格式的diff


使用参数 u 代表unified


如果两个文件相似度很高,那么上下文格式的diff,将显示大量重复的内容,很浪费空间。1990年,GNU diff率先推出了"合并格式"的diff,将f1和f2的上下文合并在一起显示。

11]# diff -u /dfs/acf/INDEX/202010/10/A1350AOIL05.TXT /dfs/acf/INDEX/202010/11/A1350AOIL05.TXT |more
--- /dfs/acf/INDEX/202010/10/A1350AOIL05.TXT  2020-10-10 23:59:37.108102000 +0800
+++ /dfs/acf/INDEX/202010/11/A1350AOIL05.TXT  2020-10-11 03:13:37.984228000 +0800
@@ -1,101494 +1,26841 @@
-002538 \A1575A1BPK1\A10A9\A10A902R\A10A902RCH\FORMAT\A1350A10A902RCH.TXT
-002538 \A1575A1BPK1\A10A9\A10A902R\A10A902RCH\GlassID\A1350A10A902RCH-Mark9.JPG
-002538 \A1575A1BPK1\A10A9\A10A902R\A10A902RCH\GlassID\A1350A10A902RCH-Mark10.JPG
-002538 \A1575A1BPK1\A10A9\A10A902R\A10A902RCH\GRAYIMAGE\A1350A10A902RCHDM.JPG

第一部分

"---"表示变动前的文件,"+++"表示变动后的文件。


第二部分

@@ -1,101494 +1,26841 @@

前面的"-1,101494 "分成三个部分:减号表示第一个文件(即f1),"1"表示第1行,"101494"表示连续101494行。合在一起,就表示下面是第一个文件从第1行开始的连续101494行。同样的,"+1,26841"表示变动后,成为第二个文件从第1行开始的连续26841行。

相关实践学习
CentOS 8迁移Anolis OS 8
Anolis OS 8在做出差异性开发同时,在生态上和依赖管理上保持跟CentOS 8.x兼容,本文为您介绍如何通过AOMS迁移工具实现CentOS 8.x到Anolis OS 8的迁移。
目录
相关文章
|
17天前
|
Linux
Linux系统之whereis命令的基本使用
Linux系统之whereis命令的基本使用
54 23
Linux系统之whereis命令的基本使用
|
4天前
|
缓存 Ubuntu Linux
Linux中yum、rpm、apt-get、wget的区别,yum、rpm、apt-get常用命令,CentOS、Ubuntu中安装wget
通过本文,我们详细了解了 `yum`、`rpm`、`apt-get`和 `wget`的区别、常用命令以及在CentOS和Ubuntu中安装 `wget`的方法。`yum`和 `apt-get`是高层次的包管理器,分别用于RPM系和Debian系发行版,能够自动解决依赖问题;而 `rpm`是低层次的包管理工具,适合处理单个包;`wget`则是一个功能强大的下载工具,适用于各种下载任务。在实际使用中,根据系统类型和任务需求选择合适的工具,可以大大提高工作效率和系统管理的便利性。
54 25
|
2天前
|
缓存 Linux
Linux查看内存命令
1. free free命令是最常用的查看内存使用情况的命令。它显示系统的总内存、已使用内存、空闲内存和交换内存的总量。 free -h • -h 选项:以易读的格式(如GB、MB)显示内存大小。 输出示例: total used free shared buff/cache available Mem: 15Gi 4.7Gi 4.1Gi 288Mi 6.6Gi 9.9Gi Swap: 2.0Gi 0B 2.0Gi • to
14 2
|
1月前
|
网络协议 Unix Linux
深入解析:Linux网络配置工具ifconfig与ip命令的全面对比
虽然 `ifconfig`作为一个经典的网络配置工具,简单易用,但其功能已经不能满足现代网络配置的需求。相比之下,`ip`命令不仅功能全面,而且提供了一致且简洁的语法,适用于各种网络配置场景。因此,在实际使用中,推荐逐步过渡到 `ip`命令,以更好地适应现代网络管理需求。
42 11
|
2月前
|
Linux Shell
Linux 10 个“who”命令示例
Linux 10 个“who”命令示例
117 14
Linux 10 个“who”命令示例
|
2月前
|
Ubuntu Linux
Linux 各发行版安装 ping 命令指南
如何在不同 Linux 发行版(Ubuntu/Debian、CentOS/RHEL/Fedora、Arch Linux、openSUSE、Alpine Linux)上安装 `ping` 命令,详细列出各发行版的安装步骤和验证方法,帮助系统管理员和网络工程师快速排查网络问题。
244 20
|
2月前
|
Linux
linux查看目录下的文件夹命令,find查找某个目录,但是不包括这个目录本身?
通过本文的介绍,您应该对如何在 Linux 系统中查看目录下的文件夹以及使用 `find` 命令查找特定目录内容并排除该目录本身有了清晰的理解。掌握这些命令和技巧,可以大大提高日常文件管理和查找操作的效率。 在实际应用中,灵活使用这些命令和参数,可以帮助您快速定位和管理文件和目录,满足各种复杂的文件系统操作需求。
159 8
|
2月前
|
网络协议 Linux 应用服务中间件
kali的常用命令汇总Linux
kali的常用命令汇总linux
167 7
|
3月前
|
Linux 数据库
Linux中第一次使用locate命令报错?????
在Linux CentOS7系统中,使用`locate`命令时出现“command not found”错误,原因是缺少`mlocate`包。解决方法是通过`yum install mlocate -y`或`apt-get install mlocate`安装该包,并执行`updatedb`更新数据库以解决后续的“can not stat”错误。
69 9
|
3月前
|
监控 网络协议 Linux
Linux netstat 命令详解
Linux netstat 命令详解