Linux diff命令(比较两个文件或目录的内容差异)

文章目录

  • Linux `diff` 命令详解教程
    • 基本用法
      • 比较文件
      • 输出解释
    • 递归比较(-r)
      • 示例代码
    • 控制输出格式
      • 统一格式(-u)
      • 上下文格式(-c)
    • 高级选项
      • 忽略所有空白差异(-w)
      • 仅报告文件是否不同

Linux diff 命令详解教程

diff 是一个在 Unix 和 Linux 系统中广泛使用的命令行工具,用于比较两个文件或目录的内容差异。本文将深入探讨 diff 命令的各种用法,包括基本比较、递归比较、输出格式控制等高级功能。

基本用法

比较文件

diff 命令最基本的用法是比较两个文件,命令格式如下:

diff [options] file1 file2

示例代码,比较两个文本文件 text1.txttext2.txt 的内容:

diff text1.txt text2.txt

在这里插入图片描述
在这里插入图片描述

如果没有任何输出,表明这两个文件在内容上是相同的。如果文件有差异,diff 会显示这些差异的具体行和内容。

输出解释

当发现两个文件不相同时,diff 输出的格式通常如下:

3c3
< one
---
> two

这表示 file1 的第三行是 “one”,而 file2 的第三行是 “two”。这里 < 符号表示第一个文件的内容,> 符号表示第二个文件的内容。

上面3c3是一种指示符,用于描述发生变化的行号和变化类型。这个特定的输出格式来自于传统的diff输出模式,这里是如何解释的:

  • 3c3 中的第一个数字 3 表示在第一个文件(通常是比较中的左侧文件)中涉及变更的起始行号。
  • c 是一个字母,表示变更的类型。在这里,c 表示 “change”(更改)。diff 使用不同的字母来表示不同类型的差异:
    • c 表示更改(change)。
    • a 表示添加(addition)。
    • d 表示删除(deletion)。
  • 第二个 3 表示在第二个文件(通常是比较中的右侧文件)中涉及变更的起始行号。

因此,3c3 告诉用户在两个文件的第三行发生了变化。

递归比较(-r)

当需要比较包含多个文件和目录的两个目录时,可以使用 -r 选项。这使 diff 能够递归地比较每个文件。

示例代码

比较两个目录 dir1dir2

diff -r dir1 dir2

在这里插入图片描述

这将输出这两个目录中所有不同的文件和子目录的差异。

控制输出格式

diff 命令提供多种输出格式,可以更清晰地理解文件之间的差异。

统一格式(-u)

使用 -u 选项可以生成易于理解和适合用于补丁的输出格式:

diff -u file1 file2

在这里插入图片描述

输出示例:

--- file1    2021-06-07 12:00:00.000000000 +0200
+++ file2    2021-06-07 12:01:00.000000000 +0200
@@ -1,5 +1,5 @@This is a file
-with
+asmallexampletext.

这里 @@ -1,5 +1,5 @@ 表明比较的是从第一行开始的共五行代码。- 表示 file1 的内容,+ 表示 file2 的内容。

上下文格式(-c)

上下文格式通过 -c 选项提供,它包含了更多周围的上下文信息,帮助理解变更的前后关系:

diff -c file1 file2

输出示例:

*** file1    2021-06-07 12:00:00.000000000 +0200
--- file2    2021-06-07 12:01:00.000000000 +0200
***************
*** 1,5 ****This is a file
- withasmallexample
--- 1,5 ----This is a file
+ asmallexample

高级选项

diff 还提供了一系列高级选项,用于忽略空白差异、只显示差异而不显示具体内容等。

忽略所有空白差异(-w)

使用 -w 选项可以忽略空格和制表符带来的差异:

diff -w file1 file2

仅报告文件是否不同

使用 -q 选项可以简洁地报告文件是否不同,而不显示具体差异:

diff -q dir1 dir2

输出示例:


plaintext
Files dir1/file1 and dir2/file1 differ

通过这些方法,可以有效地使用 diff 命令来识别和处理文件及目录间的差异,无论是进行代码审核、生成补丁文件还是简单的文件比较。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/687207.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SVN 合并到 Git 时有文件大于 100 M 被限制 Push

如果有文件大小大于 100M&#xff0c;GitHub 是会被限制推送到仓库中的&#xff0c;大概率情况会显示下面的错误&#xff1a; remote: Resolving deltas: 100% (3601/3601), done. remote: error: Trace: aea1f450da6f2ef7bfce457c715d0fbb9b0f6d428fdca80233aff34b601ff59b re…

RobbitMQ基本消息队列的消息发送过程

RabbitMQ: One broker to queue them all | RabbitMQ RabbitMQ官网 SpringAmqp的官方地址&#xff1a;Spring AMQP 代码示例:对着代码看应该能看明白 publisher:消息发送者的代码示例 package cn.itcast.mq.helloworld;import com.rabbitmq.client.Channel; import com.rabb…

线路和绕组中的波过程(一)

本篇为本科课程《高电压工程基础》的笔记。 本篇为这一单元的第一篇笔记。下一篇传送门。 当电路中的设备&#xff08;元件&#xff09;最大实际尺寸l大于人们所感兴趣的谐波波长 λ \lambda λ时&#xff0c;可以作为集中参数处理&#xff0c;否则就要当做分布参数处理。即&…

基于STM32移植lvgl(V8.2)(SPI接口的LCD)

目录 概述 1 认识LVGL 1.1 LVGL官网 1.2 LVGL库文件下载 2 认识SPI接口型LCD 2.1 PIN引脚定义 2.2 MCU IO与LCD PIN对应关系 3 实现LCD驱动 3.1 使用STM32Cube配置Project 3.2 STM32Cube生成工程 4 移植LVGL 4.1 准备移植文件 4.2 添加lvgl库文件到项目 4.2.1 src下…

linux fdisk 银河麒麟操作系统 v10 磁盘分区和挂载 详细教程

1查看 未加载的磁盘 fdisk -l 2 开始分区 fdisk /dev/vdb #查看分区 #新建分区和保存 3 格式化和挂载 fdisk -l mkfs.xfs /dev/vdb1 #查看uuid blkid /dev/vdb1 mkdir /data vi /etc/fstab UUID209daa-fb1c-48f2-bf5e-e63f38cb8a /data xfs defaults 0 0 #加载下 mo…

探秘未来科技:数字化无人巡检的奇妙之旅

嘿&#xff0c;朋友们&#xff01;下午茶时间到&#xff01;趁着这会儿咱们来聊一个超级炫酷的话题——数字化无人巡检。想象一下&#xff0c;那些曾经需要人工跋山涉水、风吹日晒的巡检工作&#xff0c;现在正被一群“智能小分队”悄悄接手&#xff0c;是不是觉得既神奇又方便…

Ascent DMS AE电源说明书和设备连接调试教程

Ascent DMS AE电源说明书和设备连接调试教程

彩虹聚合DNS管理系统

聚合DNS管理系统可以实现在一个网站内管理多个平台的域名解析&#xff0c;目前已支持的域名平台有&#xff1a;阿里云、腾讯云、华为云、西部数码、CloudFlare。本系统支持多用户&#xff0c;每个用户可分配不同的域名解析权限&#xff1b;支持API接口&#xff0c;支持获取域名…

FFmpeg常用API与示例(三)—— 音视频解码与编码

编解码层 1.解码 (1) 注册所有容器格式和 CODEC:av_register_all() (2) 打开文件:av_open_input_file() (3) 从文件中提取流信息:av_find_stream_info() (4) 穷举所有的流&#xff0c;查找其中种类为 CODEC_TYPE_VIDEO (5) 查找对应的解码器:avcodec_find_decoder() (6) …

19.接口自动化-Jekins学习

1.CI-持续集成 频繁的&#xff08;一天多次&#xff09;将代码集成到主干 目的&#xff1a;让产品快速迭代&#xff0c;保持高质量 好处&#xff1a; 快速发现错误&#xff0c;每次更新都集成到主干&#xff0c;可以快速发现错误&#xff0c;定位错误也容易防止分支大幅偏离主…

QT C++(QWidget类及其常见的属性)

文章目录 1. QWidget类及其常见的属性 1. QWidget类及其常见的属性 QT各种控件都是继承自QWidget类&#xff0c;QWidget类是QT控件体系中通用的部分。 QWidget属性如下图 常见的QT属性为&#xff1a; enabled&#xff1a;描述控件是否处于可用状态&#xff08;禁用状态这个…

idea中数据库的连接(保姆级)

点击idea中的database 然后再点击加号 创建 然后选择第一栏data source 再选择mysql 然后选择数据库的连接方式 再输入密码 这里我们本来就是localhost所有就不用改 选择端口号 然后点击Test Connection 测试连接 第一次连接会下载连接的文件 我们只需要 等待它下载完成就好了 …