diff和patch

本文详细介绍了如何使用diff命令比较两个文本文件,并通过实例展示了如何使用-b、-B、-i参数进行差异比较,以及如何将差异信息保存为patch文件,最后介绍如何应用patch文件进行文件更新或还原。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


diff [-bBi] from_file to_file

from_file:作为源文件的文件名

to_file:作为目的比较文件的文件名

注意:from_file 或 to_file 可以用"-" 代表 “Standard Input”

-b :忽略一行当中仅有多余的空格

-B:忽略空白间的区别

-i:忽略大小写


a.txt

1aaaaaaaaaaa
2bbbbbbbbbbb
3ccccccccccc
4ddddddddddd
5eeeeeeeeeee
6fffffffffff

b.txt

1aaaaaaaaaaa
2bbbbbbbbbbb
3xxxxxxxxxxx
4ddddddddddd
6fffffffffff


diff a.txt b.txt 
3c3               《== 左边的第3行被替换(c)成右边的第3行
< 3ccccccccccc    《== 左边第3行内容
---
> 3xxxxxxxxxxx    《== 右边第3行内容
5d4               《== 左边的第5行被删除(d)了,基准是右边的第4行
< 5eeeeeeeeeee    《== 列出左边(<)文件被删除那一行

做成diff文件

diff -Nuar Temp/a.txt Temp/b.txt > txt.patch

txt.patch

--- Temp/a.txt	2015-05-14 09:59:32.201103524 +0800
+++ Temp/b.txt	2015-05-14 09:59:59.625102956 +0800
@@ -1,6 +1,5 @@
 1aaaaaaaaaaa
 2bbbbbbbbbbb
-3ccccccccccc
+3xxxxxxxxxxx
 4ddddddddddd
-5eeeeeeeeeee
 6fffffffffff

打patch

patch -pN < patch_file          <== 更新
patch -R -pN < patch_file       <== 还原

-p: 后面的N表示取消几层目录
-R: 代表还原,将新文件还原成旧文件











评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值