<转载> diff 和 patch 命令

本文转载自:http://blog.chinaunix.net/uid-23390992-id-3312321.html

diff与patch命令

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

diff和patch是一对工具,数学上说,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 此参数的输出格式可用于ed的script文件。

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

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

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=<控制数值> 设置以RSC或SCCS控制修补作业。

-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 详细显示指令的执行过程。

一、为单个文件进行补丁操作

1、建立测试文件test0、test1

[[email protected] patch]$ cat >>test0<

> 111111

> 111111

> 111111

> EOF

[[email protected] patch]$ more test0

111111

111111

111111

[[email protected] patch]$ cat >>test1<

> 222222

> 111111

> 222222

> 111111

> EOF

[[email protected] patch]$ more test1

222222

111111

222222

111111

2、使用diff创建补丁test1.patch

[[email protected] patch]$ diff -uN test0 test1 > test1.patch

【注:因为单个文件,所以不需要-r选项。选项顺序没有关系,即可以是-uN,也可以是-Nu。】

[[email protected] patch]$ ls

test0 test1 test1.patch

二、为多个文件进行补丁操作

1、创建测试文件夹

[[email protected] patch]$ mkdir prj0

[[email protected] patch]$ cp test0 prj0

[[email protected] patch]$ ls

prj0 test0 test1 test1.patch

[[email protected] patch]$ cd prj0/

[[email protected] prj0]$ ls

test0

[[email protected] prj0]$ cat >>prj0name<

> --------

> prj0/prj0name

> --------

> EOF

[[email protected] prj0]$ ls

prj0name test0

[[email protected] prj0]$ cat prj0name

--------

prj0/prj0name

--------

[[email protected] prj0]$ cd ..

[[email protected] patch]$ mkdir prj1

[[email protected] patch]$ cp test1 prj1

[[email protected] patch]$ cd prj1

[[email protected] prj1]$ cat >>prj1name<

> ---------

> prj1/prj1name

> ---------

> EOF

[[email protected] prj1]$ cat prj1name

---------

prj1/prj1name

---------

[[email protected] prj1]$ cd ..

2、创建补丁

[[email protected] patch]$ diff -uNr prj0 prj1 > prj1.patch

[[email protected] patch]$ ls

prj0 prj1 prj1.patch test0 test1 test1.patch

[[email protected] patch]$ cp prj1.patch ./prj0

[[email protected] patch]$ cd prj0

[[email protected] prj0]$ patch -p1 < prj1.patch

patching file prj0name

patching file prj1name

patching file test0

patching file test1

[[email protected] prj0]$ ls

prj1name prj1.patch test1

[[email protected] prj0]$ patch -R -p1 < prj1.patch

patching file prj0name

patching file prj1name

patching file test0

patching file test1

[[email protected] prj0]$ ls

prj0name prj1.patch test0

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

总结一下:

单个文件

diff –uN from-file to-file >to-file.patch

patch –p0 < to-file.patch

patch –RE –p0 < to-file.patch

多个文件

diff –uNr from-docu to-docu >to-docu.patch

patch –p1 < to-docu.patch

patch –R –p1

通过 为知笔记 发布

时间: 2025-01-05 22:16:53

<转载> diff 和 patch 命令的相关文章

Linux中的版本控制---diff和patch命令

一.构造两个用于测试的文件 hello.txt: world.txt: 二.用diff命令比较两个文本文件的差异 对这个两个文本文件执行diff‘命令,并通过输出重定向,将差异保存在diff.txt文件中 $ diff -u hello.txt world.txt > diff.txt 参数-u是使得差异输出中带有上下文 第1,2行中的三个减号标识原始文件,三个加号标识目标文件: 第3行表示在这个差异小节中,是从原始文件的第1行开始之后的3行,目标文件从第1行到第3行: 从第4行开始的减号表示只

grep,cut,wc,sort,diff,uniq,patch命令

文本处理工具: Linux上文本处理三剑客: grep,egrep,fgrep: 文本过滤工具(模式: pattern)工具; grep:基本正则表达式,-E,-F egrep:扩展正则表达式,-G,-F fgrep:不支持正则表达式, sed: stream editor,流编辑器;文本编辑工具; awk: Linux上实现为gawk,文本报告生成器(格式化文本); 正则表达式:regual expression , regexp 由一类特殊字符及文本字符所编写的模式,其中有些字符不表示其字面

diff和patch命令简介

diff -u 1.txt 2.txt > diff.txt -u: 使差异输出带有上下文. 1 --- 1.txt 2017-01-21 07:09:19.015472013 -0500 2 +++ 2.txt 2017-01-21 07:11:26.385045822 -0500 3 @@ -5,9 +5,9 @@ 4 全拼,双拼 5 还是五笔 6 7 -是人就有可能犯错,软件更是如此. 8 - 9 -犯了错,就要扣工资!10 -11 +诗人就有可能犯错,软件更是如此.1213 改正的成本可

diff和patch命令(1)

1. diff是对两个集合的差运算,patch是对两个集合的和运算. 2. diff以逐行的方式,比较文本文件的异同处.所是指定要比较目录,则diff会比较目录中相同文件名的文件,但不会比较其中子目录,如果我们希望递归执行,需要使用-r参数. ** [[email protected] test]# diff passwd.old passwd.new 4d3 <==左边第四行被删除 (d) 掉了,基准是右边癿第三行 < adm:x:3:4:adm:/var/adm:/sbin/nologin

diff命令和patch命令

Linux就这个范儿 2.9.5 文件对比命令——diff diff命令搭建网站离不开数据库,在Linux系统上我们使用源码安装了MySQL服务器.不久我们发现 Google发布了一系列MySQL补丁,这些补丁很好很强大,这时候我们迫不及待地要把新东西更新到系统上,那就用patch命令来打补丁吧.喝水不忘打井人,那补丁又是怎么做的呢?这个任务就需要文件对比命令diff来帮忙了.diff用来比较两个文本文件的差异,是代码版本管理的基石之一.diff采用动态规划算法实现差异比较,此算法的基础是最长公

diff patch 命令制作补丁

diff 命令 diff可以比较两个文件,并可同时记录下二者的区别.制作补丁时的一般用法和常见选项为: diff [选项] 源文件(夹) 目的文件(夹) -r:递归,设置后diff会将两个不同版本源代码目录中的所有对应文件都进行一次比较,包括子目录文件: -N:确保补丁文件将正确地处理已经创建或删除文件的情况: -u:一体化diff输出(参见例1) -E, -b, -w, -B, –strip-trailing-cr 忽略各种空白,可参见文档,按需选用. 例1,有如下两个差异文件: # vers

git apply、git am打补丁.diff 和 .patch【转】

本文转载自:https://www.jianshu.com/p/e5d801b936b6 前提: 生成patch: git format-patch -M master 生成指定patch,0163bed3bf59ae74c36cc5138b4c24f1556d8304是commit id,-1是指从当前id开始,向下提交次数,包含此次且计数从1开始. 也就是说,我想要打出0163bed3bf59ae74c36cc5138b4c24f1556d8304当前的patch,则: git format

diff和patch使用指南

大纲 1.概述 2.diff的用法 3.patch的用法 4.实战演练 1.概述 diff和patch是一对工具,在数学上来说,diff是对两个集合的差运算,patch是对两个集合的和运算.     diff比较两个文件或文件集合的差异,并记录下来,生成一个diff文件,这也是我们常说的patch文件,即补丁文件.     patch能将diff文件运用于 原来的两个集合之一,从而得到另一个集合.举个例子来说文件A和文件B,经过diff之后生成了补丁文件C,那么着个过程相当于 A -B = C

【转】patch命令

原文网址:http://bbs.chinaunix.net/thread-1945698-1-1.html patch给文件1应用补丁文件变成另外一个文件2(需要先用"diff 文件1 文件2"生成补丁文件).语法patch [选项] [原始文件 [补丁文件]] 描述: patch 命令读取如何更改文件的源文件指示信息,然后应用这些更改.源文件包含由 diff 命令产生的差别列表(或者 diff 列表).差异列表是比较两个文件和构建关于如何纠正差别的指示信息的结果.缺省情况下,patc