• 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-

  • 相关阅读:
    Swift新手教程3-字符串String
    BZOJ 2006 NOI2010 超级钢琴 划分树+堆
    Makefile学习(一)[第二版]
    leetcode 26 -- Remove Duplicates from Sorted Array
    谈谈我眼中的泛型
    oracle表空间查询维护命令大全之三(暂时表空间)史上最全
    超大表盘手表 : 超大表盘手表图片及搭配,超大表盘手表价格-美丽说
    Linux下安装Python3.3.0
    朝阳公园朝阳公园水下猎人潜水艇团购:水下猎人潜艇观光+水下梭镖打鱼套票!体验前所未有的水下休闲娱乐,探寻海底世界-聚齐北京团购
    隐形选购指南_亿超眼镜网
  • 原文地址:https://www.cnblogs.com/kumulinux/p/2149234.html
Copyright © 2020-2023  润新知