首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >Linux之diff命令

Linux之diff命令

作者头像
入门笔记
发布2022-06-02 17:00:33
发布2022-06-02 17:00:33
1.4K0
举报
文章被收录于专栏:入门小站入门小站

diff 命令是 linux上非常重要的工具,用于比较文件的内容,特别是比较两个版本不同的文件以找到改动的地方。diff在命令行中打印每一个行的改动。最新版本的diff还支持二进制文件。diff程序的输出被称为补丁 (patch),因为Linux系统中还有一个patch程序,可以根据diff的输出将a.c的文件内容更新为b.c。diff是svn、cvs、git等版本控制工具不可或缺的一部分。

命令格式

diff[参数][文件1或目录1][文件2或目录2]

命令功能

diff命令能比较单个文件或者目录内容。如果指定比较的是文件,则只有当输入为文本文件时才有效。以逐行的方式,比较文本文件的异同处。如果指定比较的是目录的的时候,diff 命令会比较两个目录下名字相同的文本文件。列出不同的二进制文件、公共子目录和只在一个目录出现的文件。

diffnormal显示格式有三种提示:

  • a - add
  • c - change
  • d - delete

对比两个文件

代码语言:javascript
复制
> cat -n 1.txt 
     1  入门小站
     2  123
     3  rumenz
> cat -n 2.txt 
     1  入门小站
     2  456
     3  123
     4
     5  入门

> diff 1.txt 2.txt
1a2
> 456
3c4,5
< rumenz
---
> 
> 入门
  • 1a2表示1.txt的第1行后面添加4562.txt文件的第2行相同。
  • 3c4,5表示将1.txt的第3行改成2.txt的第4,5行内容之后两个文件相等。

并排格式输出

代码语言:javascript
复制
> diff 1.txt 2.txt -y -W 50
入门小站                入门小站
                      > 456
123                     123
rumenz                |
                      > 入门
  • |表示前后2个文件内容有不同
  • <表示后面文件比前面文件少了1行内容
  • >表示后面文件比前面文件多了1行内容

上下文输出格式

代码语言:javascript
复制
> diff 1.txt 2.txt -c
*** 1.txt       2021-02-28 22:19:02.872483347 +0800
--- 2.txt       2021-02-28 22:19:29.834776319 +0800
***************
*** 1,3 ****
  入门小站
  123
! rumenz
--- 1,5 ----
  入门小站
+ 456
  123
! 
! 入门
  • 比较的文件的后者比前着多一行
  • 比较的文件的后者比前着少一行
  • ! 比较的文件两者有差别的行

统一格式输出

代码语言:javascript
复制
> diff 1.txt 2.txt -u
--- 1.txt       2021-02-28 22:19:02.872483347 +0800
+++ 2.txt       2021-02-28 22:19:29.834776319 +0800
@@ -1,3 +1,5 @@
 入门小站
+456
 123
-rumenz
+
+入门
第一部分
  • --- 1.txt 2021-02-28 22:19:02.872483347 +0800
  • +++ 2.txt 2021-02-28 22:19:29.834776319 +0800
  • "---"表示变动前的文件,"+++"表示变动后的文件。
第二部分

变动的位置用两个@作为起首和结束

  • @@ -1,3 +1,5 @@

前面的-1,3分成三个部分:减号表示第一个文件(即1.txt),"1"表示第1行,"3"表示连续3行。合在一起,就表示下面是第一个文件从第1行开始的连续3行。同样的,"+1,5"表示变动后,成为第二个文件从第1行开始的连续5行。

比较两个文件不同,并生产补丁

代码语言:javascript
复制
> diff -ruN 1.txt 2.txt > patch.log
> cat patch.log 
--- 1.txt       2021-02-28 22:19:02.872483347 +0800
+++ 2.txt       2021-02-28 22:19:29.834776319 +0800
@@ -1,3 +1,5 @@
 入门小站
+456
 123
-rumenz
+
+入门

打补丁,让两个文件一样

代码语言:javascript
复制
> patch 1.txt patch.log 
patching file 1.txt

> cat 1.txt 
入门小站
456
123

入门
> cat 2.txt 
入门小站
456
123

入门

比较目录差异

代码语言:javascript
复制
> tree src/
src/
├── test1
│   └── one
├── test2
└── test3

4 directories, 0 files


> tree dst/
dst/
├── test1
├── test2
│   └── one
└── test3

4 directories, 0 files

> diff -r src/ dst/
Only in src/test1: one
Only in dst/test2: one

原文链接:https://rumenz.com/rumenbiji/linux-diff.html

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-12-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 入门小站 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 命令格式
  • 命令功能
  • diff的normal显示格式有三种提示:
  • 对比两个文件
  • 并排格式输出
  • 上下文输出格式
  • 统一格式输出
    • 第一部分
    • 第二部分
  • 比较两个文件不同,并生产补丁
  • 打补丁,让两个文件一样
  • 比较目录差异
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档