veket官方网站论坛

veket

 找回密码
 要注册
搜索
查看: 6063|回复: 0

diff比较两个目录下不同文件的命令

[复制链接]
发表于 2009-7-29 09:54 | 显示全部楼层 |阅读模式
diff
  diff 是Linux命令
  用途
  比较文本文件。
  语法
  比较两个文件的内容
  diff [ -c | -C Lines | -D [ String ] | -e | -f | -n ] [ -b ] [ -i] [ -t ] File 1 File2
  diff [ -h ] [ -b ] File 1 File2
  排序字典的内容并比较不同的文件
  diff [ -c | -C Lines | -e | -f | -n ] [ -b ] [ -i ] [ -l ] [ -r ] [ -s ] [ -S File ] [ -t ] [ -w ] Directory1 Directory2
  diff [ -h ] [ -b ] Directory1 Directory2
  描述
  diff 命令比较文本文件。它能比较单个文件或者目录内容。
  注:
  diff 命令只有当输入为文本文件时才有效。
  如果指定了 Directory1 和 Directory2 参数,diff 命令比较两个目录下名字相同的文本文件。列出不同的二进制文件、公共子目录和只在一个目录出现的文件。
  当 diff 命令运行于常规文件时,且当目录比较期间比较不同的文本文件时,diff 命令显示文件中哪些行必须更改以保持它们一致。如果 File1 和 File2 参数都不是目录,其中之一可能给定负号“-”,以采用标准输入。如果 File1 参数是目录,则使用目录中与 File2 参数指定的文件名一致的那个文件。
  典型的输出包含这些格式的行:
  Lines Affected in File1 Action Lines Affected in File2
  Number1 a Number2[,Number3]
  Number1[,Number2] d Number3
  Number1[,Number2] c Number3[,Number4]
  这些行类似于 ed 子命令将 File1 文件转换成 File2 文件。Action 字母之前的数字指 File1;后面的数字则指 File2。因此,通过将 a 替换成 d,从右往左读,您就能知道如何将 File2 转换成 File1。在 ed 命令下,相同的对(即 Number1 = Number2)会简略为单个数字。
  下列每一行,diff 命令显示以 <:(小于符号,冒号)开始的第一个文件中的所有受影响行,然后显示以 >(大于符号)开始的第二个文件中的所有受影响行。
  退出值 0 表示没有不同,1 表示找到不同处,2 表示出错。
  注:
  如果指定了多于一个的 -c、-C、-D、-e、-f 或者 -n 标志,命令行上的最后一个具有优先权。系统不发出错误消息。
  标志
  -b 将每行末尾当作单个新行标记处理(忽略新行字符前的空格字符)的任意数量空格字符与其他空格字符串(除了新行标记)同样地比较。
  -C Lines 启动 diff 命令,但只比较 Lines 变量指定的行数。-C 标志稍微修改输出。输出以文件的相同部分和创建日期开始。每个更改以 12 个 *(星号)组成的行分隔。从 File1 中要删的行以 -(减号)标记,File2 中要添加的行以 +(加号)标记。从一个文件更改到另一个文件的行在两个文件中都以 !(惊叹号)标记。在每一个文件的指定上下文行中的更改会被整组一起输出。
  -c 启动 diff 命令,比较三行上下文。-c 标志稍微修改输出。输出以涉及文件的标识和它们的创建日期开始。每个更改以 12 个 *(星号)组成的行分隔。File1 中要删的行以 -(减号)标记,要被添加到 File2 的行以 + (加号)标记。从一个文件更改到另一个文件的行在两个文件中都以 !(惊叹号)标记。在每一个文件的指定上下文行中的更改会被整组一起输出。
  -D [ String ] 使得 diff 命令在标准输出上建立一个 File1 和 File2 的合并版本。包含了 C 预处理器控件以便没有定义 String 的结果编译等同于编译 File1,同时定义 String 产生 File2。
  -e 以适合 ed 编辑器的格式进行输出,将 File1 转换成 File2。当使用这个标志时,以下 shell 程序可以帮助维护一个文件的多个版本。手头仅需要由 diff 命令生成的一个祖先文件($1)和一系列版本的 ed 脚本($2、$3、...)。标准输出上的最近版本如下:
  (shift; cat $*; echo '1,$p') | ed - $1
  当使用 -e 标志比较目录时,输出上添加了额外的命令,因此,结果是一个 shell 脚本,将两个目录上的共有文本文件从 Directory1 上的状态转换到 Directory2 上的状态。
  注:
  由 -e 或 -f 标志产生的编辑脚本无法创建由单个组成的行。(周期)。
  -f 以不适合 ed 编辑器的格式创建输出,按照在 -e 标志下产生的逆向顺序显示从 File1 到 File2 的转换的必要修改。
  -h 如果要更改的部分比较短而且分隔清晰,则执行备用的比较可能会更快。-h 标志可用于任意长度的文件。-c、-C、-D、-e、-f 和 -n 标志无法与 -h 标志一起使用。当使用 -h 标志时,除了 -b 标志,其他标志一律忽略。
  -i 忽略字母大小写。例如,小写 a 被认为同大写 A 一样。
  -l 长输出格式。每个由文本文件比较 diff 命令获得的结果通过命令 pr 输送分页。在报告所有文本文件不同之处后,其他不同之处将被记忆和总结。
  -n 产生类似于 -e 标志创建的输出,但是顺序相反,而且在每一插入或删除命令上进行更改计数。这是修订控件系统(RCS)所用的格式。
  -r 使 diff 命令的应用程序递归到遇到的公共子目录。
  -s 报告相同的文件,否则不提。
  -S [ File ] 当比较目录时,忽略在 File 变量指定的文件之前整理名称的文件。-S 标志只用于 Directory1 和 Directory2 参数指定的目录。如果您将 -r 标志与 -S 标志一起使用, -S 标志在 Directory1 和 Directory2 子目录中不进行递归。
  -t 在输出行扩展制表符。典型输出或者 -c 标志输出会添加字符到每一行首,这会影响初始行的缩进,使得输出列表难以解释。该标志则保留原始源的缩进。
  -w 忽略所有空格和制表符,将所有其他空白字符串视为一致。例如,if ( a == b ) 与 if(a==b) 相等。
  退出状态
  此命令返回下列退出值:
  0 未找到不同处。
  1 找到不同处。
  >1 发生错误。
  示例
  1. 要比较两个文件,请输入:
  diff chap1.back chap1
  这显示文件 chap1.bak 和 chap1 的不同处。
  2. 要比较两个文件,但是忽略空格字符个数的区别,请输入:
  diff -w prog.c.bak prog.c
  如果两行仅仅空格和制表符数目不同,则 diff -w 目录认为它们相等。
  3. 要创建一个包含 ed 命令可以用于从另一个文件重构文件的命令的文件,请输入:
  diff -e chap2 chap2.old >new.to.old.ed
  这将创建一个名为 new.to.old.ed 的文件,它包含 ed 子命令,把 chap2 转换回在 chap2.old 中找到的文本版本。在大多数情况下,new.to.old.ed 比 chap2.old 要小很多。您可以通过删除 chap2.old 以节省磁盘空间,您也可以在任何时候重建它,通过输入:
  (cat new.to.old.ed ; echo '1,$p') | ed - chap2 >chap2.old
  括号中的命令把 1,$p 添加到编辑命令的末尾,发送给 ed 编辑器。1,$p 使得 ed 命令在编辑完成后将文件写到标准输出。这一修改的命令序列然后从管道传给 ed 命令(| ed),编辑器读取它作为标准输入。- 标志使 ed 命令不显示文件大小以及其他附加信息因为它们易与 chap2.old 的文本混肴。
  文件
  /usr/bin/diff 包含 diff 命令。
  diff和patch的使用
  1) diff/patch这对工具在数学上来说,diff是对2个集合求差,patch是求和
  diff A B > C 生成A和B的diff文件C
  patch A C 给A打上diff文件得到B
  patch -R B C B还原为A
  2) 内核补丁
  生成
  diff -uNr linux-2.6.xxx linux-2.6.xxx.1 > diff.patch
  升级
  cp diff.patch linux-2.6.xxx/.
  cd linux-2.6.xxx
  patch -p1 < diff.patch
您需要登录后才可以回帖 登录 | 要注册

本版积分规则

QQ|手机版|Archiver|veket官方网站论坛 ( 粤ICP备 11052856 )

GMT+8, 2024-5-15 09:15

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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