diff用于比较文件或目录内容,特别是比较两个版本不同的文件以找到改动的地方。

如果指定比较的是文件,则只有当输入为文本文件时才有效,以逐行的方式,比较文本文件的异同处。

如果指定比较的是目录的的时候,diff命令会比较两个目录下名字相同的文本文件,列出不同的二进制文件、公共子目录和只在一个目录出现的文件。

基本命令参数:

-a   所有的文件都视为文本文件来逐行比较,甚至他们似乎不是文本文件.

-b   忽略空格引起的变化.

-B   忽略插入删除空行引起的变化.

-c   输出数字(默认为3行) 复制上下文.

-e   输出一个ed脚本.

-n   输出一个RCS格式diff

-q   仅报告文件是否相异,不在乎差别的细节.

-s   报告两个文件相同.

-r   比较子目录中的文件。

-v   显示版本信息

-y   以并列的方式显示文件的异同之处。

-i   不检查大小写的不同。

-H   比较大文件时,可加快速度。

-u   以合并的方式来显示文件内容的不同。

-w   忽略全部的空格字符。

...  ...

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

实例:

两个文件:

程序清单1:log2013.c

2013-01

2013-02

2013-03

2013-04

2013-05

2013-06

2013-07

2013-08

2013-09

2013-10

程序清单2:log2014.c

2013-01

2013-02

2014-03

2013-04

2013-05

2013-06

2013-07

2013-07

2013-09

2013-10

2013-11

2013-12

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

我们使用diff命令来查看这两个文件的不同之处,有以下几种方便的方法:

① 普通格式输出:

[root@localhost diff]# diff log2013.c log2014.c

3c3

< 2013-03

---

> 2014-03

8c8

< 2013-08

---

> 2013-07

10a11,12

> 2013-11

> 2013-12

[root@localhost diff]# diff log2014.c log2013.c
3c3

< 2014-03

---

> 2013-03

8c8

< 2013-07

---

> 2013-08

11,12d10

< 2013-11

< 2013-12
说明:

“3c3”和“8c8”表示log2014.c和log2013.c文件在第3行和第8行内容有所不同;

“11,12d10”表示第一个文件比第二个文件多了第11和12行。

diff的normal 显示格式有三种提示:

a - add

c - change

d - delete

② 并排格式输出
[root@localhost diff]# diff log2013.c log2014.c -y -W 50
2013-01      2013-01

2013-02      2013-02

2013-03    | 2014-03

2013-04      2013-04

2013-05      2013-05

2013-06      2013-06

2013-07      2013-07

2013-08    | 2013-07

2013-09      2013-09

2013-10      2013-10

> 2013-11

> 2013-12

[root@localhost diff]# diff log2014.c log2013.c -y -W 50

2013-01      2013-01

2013-02      2013-02

2014-03    | 2013-03

2013-04      2013-04

2013-05      2013-05

2013-06      2013-06

2013-07      2013-07

2013-07    | 2013-08

2013-09      2013-09

2013-10      2013-10

2013-11   <

2013-12   <

说明:

这种并排格式的对比一目了然,可以快速找到不同的地方。
-W选择可以指定输出列的宽度,这里指定输出列宽为50

“|”表示前后2个文件内容有不同

“<”表示后面文件比前面文件少了1行内容

“>”表示后面文件比前面文件多了1行内容

③ 上下文输出格式
[root@localhost diff]# diff log2013.c log2014.c -c
*** log2013.c2015-08-03 04:40:06.046896412 -0400

--- log2014.c2015-08-03 04:42:30.241574972 -0400

***************

*** 1,10 ****

2013-01

2013-02

! 2013-03

2013-04

2013-05

2013-06

2013-07

! 2013-08

2013-09

2013-10

--- 1,12 ----

2013-01

2013-02

! 2014-03

2013-04

2013-05

2013-06

2013-07

! 2013-07

2013-09

2013-10

+ 2013-11

+ 2013-12

说明:

这种方式在开头两行作了比较文件的说明,这里有三中特殊字符:
+ 比较的文件的后者比前者多一行
- 比较的文件的后者比前者少一行
! 比较的文件两者有差别的行

④ 统一输出格式
[root@localhost diff]# diff log2014.c log2013.c -u
--- log2014.c2015-08-03 04:42:30.241574972 -0400

+++ log2013.c2015-08-03 04:40:06.046896412 -0400

@@ -1,12 +1,10 @@

2013-01

2013-02

-2014-03

+2013-03

2013-04

2013-05

2013-06

2013-07

-2013-07

+2013-08

2013-09

2013-10

-2013-11

-2013-12

说明:

正如看到的那样,统一格式的输出更加紧凑,所以更易于理解,更易于修改。

它的第一部分,也是文件的基本信息:

--- log2014.c2015-08-03 04:42:30.241574972 -0400

+++ log2013.c2015-08-03 04:40:06.046896412 -0400

“---”表示变动前的文件,

“+++”表示变动后的文件。

第二部分,变动的位置用两个@作为起首和结束。

@@ -1,12 +1,10 @@

前面的"-1,12"分成三个部分:减号表示第一个文件(即log2014.c),"1"表示第1行,"12"表示连续12行。

合在一起,就表示下面是第一个文件从第1行开始的连续12行。

同样的,"+1,10"表示变动后,成为第二个文件从第1行开始的连续10行。

⑤ 其他

假如你想查看两个文件是否不同又不想显示差异之处的话,可以加上-q选项:
[root@localhost diff]# diff log2013.c log2014.c -q
Files log2013.c and log2014.c differ

另外你还可以提供一些匹配规则来忽略某中差别,可以用 -I regexp
[root@localhost diff]# diff log2013.c log2014.c -c -I include
*** log2013.c2015-08-03 04:40:06.046896412 -0400

--- log2014.c2015-08-03 04:42:30.241574972 -0400

***************

*** 1,10 ****

2013-01

2013-02

! 2013-03

2013-04

2013-05

2013-06

2013-07

! 2013-08

2013-09

2013-10

--- 1,12 ----

2013-01

2013-02

! 2014-03

2013-04

2013-05

2013-06

2013-07

! 2013-07

2013-09

2013-10

+ 2013-11

+ 2013-12

这里通过“ -I include”选项来忽略带有“ include”字样的行

linux文件对比命令——diff的更多相关文章

  1. 修改linux文件权限命令:chmod 【转载】

    Linux系统中的每个文件和目录都有访问许可权限,用它来确定谁可以通过何种方式对文件和目录进行访问和操作. chmod  命令可以改变所有子目录的权限,下面有2种方法 改变一个文件的权限: chmod ...

  2. Linux文件系统管理命令(第二版)

    Linux文件系统管理命令 常用命令 1.df命令 查看分区使用情况 常用选项 -h 比较人性化 -m 以兆字节显示分区使用情况 显示信息: Mounted on:挂载点 Filesystem:对应的 ...

  3. Linux系统运维笔记(二),Linux文件编辑命令

    Linux系统运维笔记 Linux文件编辑命令 首先我们使用命令 vi filename 打开一个文件,这个时候进入到的是命令模式 接下来我们按i,然后键盘随便输入写内容. 然后按ESC重新进入到命令 ...

  4. 修改linux文件权限命令

    修改linux文件权限命令:chmod Linux系统中的每个文件和目录都有访问许可权限,用它来确定谁可以通过何种方式对文件和目录进行访问和操作. 文件或目录的访问权限分为只读,只写和可执行三种.以文 ...

  5. Linux文件查找命令find,xargs详述【转】

    转自:http://blog.csdn.net/cxylaf/article/details/4069595 转自http://www.linuxsir.org/main/?q=node/137 Li ...

  6. linux 文件类命令笔记

    看一下linux的教程,不错,由于只看鸟哥有点空洞,于就是找了个视频教程,边看边学 对比了几个教程,http://edu.51cto.com/course/course_id-32.html这个教程相 ...

  7. Linux系列教程(六)——Linux文件搜索命令

    前一篇博客我们讲解了Linux链接命令和权限管理命令, 通过 ln -s  链接名 表示创建软链接,不加-s表示创建硬链接:还有三个更改权限的命令,chmod命令可以更改文件或目录权限,chown命令 ...

  8. Linux文件搜索命令

    文件搜索命令:locate locate 文件名 在后台数据库中按文件名搜索,搜索速度很快(比find命令要快得多) locate命令所搜索的后台数据库的位置:/var/bin/mlocate 支持模 ...

  9. Linux文件挂载命令mount

    在linux系统中硬盘.u盘.光驱等其他设备都需要挂载后才能正常使用.下面是对挂载命令mount使用方法的一些总结. 文件挂载命令mountmount [-t 文件系统类型][-L卷标名][-o特殊选 ...

随机推荐

  1. MVC系列——MVC源码学习:打造自己的MVC框架(二:附源码)

    前言:上篇介绍了下 MVC5 的核心原理,整篇文章比较偏理论,所以相对比较枯燥.今天就来根据上篇的理论一步一步进行实践,通过自己写的一个简易MVC框架逐步理解,相信通过这一篇的实践,你会对MVC有一个 ...

  2. 2016HDU校赛

    A: 真正的粉丝,就算不写题解也知道怎么做 B: 最基础的数位dp C: 贪心 易得要洗衣服的地位比要脱干衣服的地位高,于是先尽可能的按10件洗衣服,最后剩下要洗的衣服数量就是0~9. 再分成0~3, ...

  3. 以.net core重构原有.net framework过程中的一些API变更记录(持续更新)

    1)Type.IsGenericType类似属性变更 以下是.net framework 4.5中Type抽象类中泛型类型的几个个属性,用于泛型类型的相关信息判断: 以下是.net core(nets ...

  4. js判断浏览器类型

    使用navigator.userAgent和来判断 PC端: <script type="text/javascript">var ua=navigator.userA ...

  5. [POJ&HDU]杂题记录

    POJ2152 树形dp,每次先dfs一遍求出距离再枚举所有点转移即可. #include<iostream> #include<cstdio> #include<cma ...

  6. 埃拉托色尼筛法(Sieve of Eratosthenes)求素数。

    埃拉托色尼筛法(Sieve of Eratosthenes)是一种用来求所有小于N的素数的方法.从建立一个整数2~N的表着手,寻找i? 的整数,编程实现此算法,并讨论运算时间. 由于是通过删除来实现, ...

  7. R 单变量重命名与删除

    单变量重命名 b = rename(b,c(target="flag")) 单变量删除    b = b[,names(b)!='age'] 或者 b[,"age&quo ...

  8. sql 批量插入数据到Sqlserver中 效率较高的方法

    使用SqlBulk #region 方式二 static void InsertTwo() { Console.WriteLine("使用Bulk插入的实现方式"); Stopwa ...

  9. form表单练习

    注册页面的设计 <body leftmargin="400px" topmargin="200px"> <form method=" ...

  10. bootstrap学习笔记--bootstrap组件

    前面已经学习了bootstrap环境搭建以及基本布局方面的知识,下面将学习下关于bootstrap的相关组件,知识点有点多. 关于bootstrap组件知识点目录: Bootstrap--代码显示 B ...