linux下diff和patch命令

diffpatch命令

diffpatch命令真可谓是天作之合,命令中的黄金搭档。老师讲了之后其实自己不是很懂,因为上课的时候没有好好听,上课走神了。怎么办呢,肯定不能放着不管了,而这两个命令确实很重要,所以只能厚着脸皮课后死啃资料自己学习咯,学了之后才有开头第一句的感慨。

 

diffpatch是一对工具,数学上说,diff是对两个集合的差运算,patch是对两个集合的和运算。diff比较两个文件或文件集合的差异,并记录下来,生成一个diff文件,就是patch文件,即补丁文件。

 

功能说明:比较文件的差异。

 

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

 

补充说明:diff以逐行的方式,比较文本文件的异同处。所是指定要比较目录,则diff会比较目录中相同文件名的文件,但不会比较其中子目录。

 

参  数:

-<行数> 指定要显示多少行的文本。此参数必须与-c-u参数一并使用。

-a--text diff预设只会逐行比较文本文件。

-b--ignore-space-change 不检查空格字符的不同。

-B--ignore-blank-lines 不检查空白行。

-c 显示全部内文,并标出不同之处。

-C<行数>--context<行数> 与执行"-c-<行数>"指令相同。

-d--minimal 使用不同的演算法,以较小的单位来做比较。

-D<巨集名称>ifdef<巨集名称> 此参数的输出格式可用于前置处理器巨集。

-e--ed 此参数的输出格式可用于edscript文件。

-f-forward-ed 输出的格式类似edscript文件,但按照原来文件的顺序来显示不同处。

-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参数时,仅显示不同之处。

 

 

[root@haha lianxi]# diff a.txt a1.txt  对比两个文档的差别

2,3d1                                 d表示删除del

< aefaf

< hello

4a3,4                                a表示增加add,另外还有个c,表示chage

> hello

> qwdqwd

[root@haha lianxi]# diff -c a.txt a1.txt  -c参数表示,显示全部内文,并标出不同之处

*** a.txt       2011-07-19 20:26:14.000000000 +0800

--- a1.txt      2011-07-19 20:33:52.000000000 +0800

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

*** 1,5 ****

  afawf

- aefaf

- hello

 

  fdxzhgth

--- 1,5 ----

  afawf

 

+ hello

+ qwdqwd

  fdxzhgth

[root@haha lianxi]# diff -u a.txt a1.txt              以合并的方式显示内容

--- a.txt       2011-07-19 20:26:14.000000000 +0800

+++ a1.txt      2011-07-19 20:33:52.000000000 +0800

@@ -1,5 +1,5 @@

 afawf

-aefaf

-hello

 

+hello

+qwdqwd

 fdxzhgth

 

生成补丁:

[root@localhost excise]# diff -u file1 file2>patchfile

[root@localhost excise]# cat patchfile

--- file1       2011-07-19 22:00:18.000000000 +0800

+++ file2       2011-07-19 22:01:05.000000000 +0800

@@ -1,5 +1,7 @@

 acdcad

+asdfsd

 dasffdfsa

 asdfasdf

 asdfsad

-aefawe

+

+badmanm

[root@localhost excise]#

 

打补丁:

[root@localhost excise]# patch file1 <patchfile

patching file file1

[root@localhost excise]# diff file1 file2

[root@localhost excise]#

 

Patch的用法:

 

patch用于根据原文件和补丁文件生成目标文件。还是拿上个例子来说,patch A C 就能得到B, 这一步叫做对A打上了B的名字为C的补丁。之一步之后,你的文件A就变成了文件B。如果你打完补丁之后想恢复到A怎么办呢?patch -R B C 就可以重新还原到A了。所以不用担心会失去A的问题。

 

功能说明:修补文件。

 

语  法:patch [-bceEflnNRstTuvZ][-B <备份字首字符串>][-d <工作目录>][-D <标示符号>][-F <监别列数>][-g <控制数值>][-i <修补文件>][-o <输出文件>][-p <剥离层级>][-r <拒绝文件>][-V <备份方式>][-Y <备份字首字符串>][-z <备份字尾字符串>][--backup-if -mismatch][--binary][--help][--nobackup-if-mismatch][--verbose][原始文件 <修补文件>] path [-p <剥离层级>] < [修补文件]

 

补充说明:patch指令让用户利用设置修补文件的方式,修改,更新原始文件。倘若一次仅修改一个文件,可直接在指令列中下达指令依序执行。如果配合修补文件的方式则能一次修补大批文件,这也是Linux系统核心的升级方法之一。

 

参  数:

-b--backup 备份每一个原始文件。

-B<备份字首字符串>--prefix=<备份字首字符串> 设置文件备份时,附加在文件名称前面的字首字符串,该字符串可以是路径名称。

-c--context 把修补数据解译成关联性的差异。

-d<工作目录>--directory=<工作目录> 设置工作目录。

-D<标示符号>--ifdef=<标示符号> 用指定的符号把改变的地方标示出来。

-e--ed 把修补数据解译成ed指令可用的叙述文件。

-E--remove-empty-files 若修补过后输出的文件其内容是一片空白,则移除该文件。

-f--force 此参数的效果和指定"-t"参数类似,但会假设修补数据的版本为新 版本。

-F<监别列数>--fuzz<监别列数> 设置监别列数的最大值。

-g<控制数值>--get=<控制数值> 设置以RSCSCCS控制修补作业。

-i<修补文件>--input=<修补文件> 读取指定的修补问家你。

-l--ignore-whitespace 忽略修补数据与输入数据的跳格,空格字符。

-n--normal 把修补数据解译成一般性的差异。

-N--forward 忽略修补的数据较原始文件的版本更旧,或该版本的修补数据已使 用过。

-o<输出文件>--output=<输出文件> 设置输出文件的名称,修补过的文件会以该名称存放。

-p<剥离层级>--strip=<剥离层级> 设置欲剥离几层路径名称。

-f<拒绝文件>--reject-file=<拒绝文件> 设置保存拒绝修补相关信息的文件名称,预设的文件名称为.rej

-R--reverse 假设修补数据是由新旧文件交换位置而产生。

-s--quiet--silent 不显示指令执行过程,除非发生错误。

-t--batch 自动略过错误,不询问任何问题。

-T--set-time 此参数的效果和指定"-Z"参数类似,但以本地时间为主。

-u--unified 把修补数据解译成一致化的差异。

-v--version 显示版本信息。

-V<备份方式>--version-control=<备份方式> "-b"参数备份目标文件后,备份文件的字尾会被加上一个备份字符串,这个字符串不仅可用"-z"参数变更,当使用"-V"参数指定不同备份方式时,也会产生不同字尾的备份字符串。

-Y<备份字首字符串>--basename-prefix=--<备份字首字符串> 设置文件备份时,附加在文件基本名称开头的字首字符串。

-z<备份字尾字符串>--suffix=<备份字尾字符串> 此参数的效果和指定"-B"参数类似,差别在于修补作业使用的路径与文件名若为src/linux/fs/super.c,加上"backup/"字符串后,文件super.c会备份于/src/linux/fs/backup目录里。

-Z--set-utc 把修补过的文件更改,存取时间设为UTC

--backup-if-mismatch 在修补数据不完全吻合,且没有刻意指定要备份文件时,才备份文件。

--binary 以二进制模式读写数据,而不通过标准输出设备。

--help 在线帮助。

--nobackup-if-mismatch 在修补数据不完全吻合,且没有刻意指定要备份文件时,不要备份文件。

--verbose 详细显示指令的执行过程。

 

以下命令接上一层命令:

[root@localhost excise]# patch -R file1 patchfile

patching file file1

[root@localhost excise]# diff file1 file2

1a2

> asdfsd

5c6,7

< aefawe

---

> badmanm

[root@localhost excise]#

 

对整个目录一次性<span style="font-family:"Lucida sans"" lang="en-

posted @ 2011-07-20 07:43  枯木-Linux  阅读(1699)  评论(0编辑  收藏  举报