Linux - Shell - diff
概述
- linux diff 命令
背景
- 一个 比较文本差异 的工具
- 老实说, 之前 git/gitlab 上比较代码差异, 我是有点懵逼的
- diff 命令, 可以作为理解这些东西的基础
- diff 命令很实用
- 支持多种比较对象
- 文本
- 目录
- 标准输入
- 今天只讲文本, 因为其他的还不会
- 支持多种比较对象
- diff 命令很实用
- 学会了, 可以有很多场景, 稳赚不赔啊
- diff
- vimdiff
- git
- gitlab
- svn
环境
- os
- centos7
- os
思路
- 基础的比较
- 命令怎么用
- 命令结果
- 慢慢的拓展
- 各个参数的使用
- 总结
- 参数
- 基础的比较
1. 基础: 最简命令与参数
概述
- 简述 diff 的基本思路
思路
两个参数
- 作为一个 用来比较 的命令, 通常会需要 两个对象
- 比如各种广告
- 植发前, 植发后, 效果一下, 就出来了
- 比如各种广告
- 作为一个 用来比较 的命令, 通常会需要 两个对象
参照
- 找不同
- 比较的目的, 肯定是为了 找不同
- 这个还是比较简单, 只要把不同的地方圈出来, 就可以了
- 描述不同
- 如果想要比较清晰的描述不同, 那么就需要一个参照
- 植发广告的参照, 大家默认都是 植发前
- 你看那个秃子, 植发了之后, 多了多少头发
- 植发前, 就是基准
- 这样的结果, 就是描述起来, 会清晰很多
- 植发广告的参照, 大家默认都是 植发前
- 如果想要比较清晰的描述不同, 那么就需要一个参照
- diff
- 参数
- 文本1
- 参照
- 文本2
- 变化
- 以 文本1 为基础
- 所有的不同和变化, 都作为 文本1的变化 为准来描述
- 变化
- 文本1
- 参数
- 找不同
命令
格式
# doc1 是基准
# doc2 是相对 doc1 的变化
> diff [-option] <doc1> <doc2>
2. 场景1: 两个文本一模一样
概述
- 场景, 没有变化
命令
# 1. 假设文本叫 note
> diff note note
结果
- 不会有任何输出
- 这是一个简单但又必须知道的场景
- 如果不信, 可以在 参数前加上 -y 的选项
- 不会有任何输出
3. 场景2: 变化 - 变化
概述
- 比较简单的变化
文本
note1
1
2
3
4
5
6
7
8
9
0
note2
10
2
30
40
50
6
70
71
72
8
90
命令
> diff note1 note2
结果
# 1. 1c1: note1 的 第1行, 经过了 修改, 变成了 note2 的 第1行
1c1
# < 开头, 是 note1 的内容
< 1
# --- 华丽的分割线
---
# > 开头, 是 note2 的内容
> 10
# 2. 3,5c3,5: note1 的 3到5行, 改成了 note2 的 3到5行
3,5c3,5
< 3
< 4
< 5
---
> 30
> 40
> 50
# 3. 7c7,9: note1 的 7 行, 改成了 note2 的 7到9行
7c7,9
< 7
---
> 70
> 71
> 72
# 4. 9,10c11: note1 的 9到10行, 改成了 note2 的 11行
9,10c11
< 9
< 0
---
> 90
# 5. 还会有 左右 不对称 的 多对多, 我就不讲了, 大家应该能够理解
4. 场景3: 变化 - 添加
概述
- 稍微麻烦点的变化
- 主要是 不好理解
文本
note1
1
2
3
4
5
note2
1
10
2
3
4
40
41
42
5
51
命令
> diff note1 note2
结果
# 为了变成 note2, note1 的 第1行 后面, 添加了内容, 对应 note2 的 第2行
1a2
# 为了变成 note2, note2 里添加的内容
> 10
# 为了变成 note2, note1 的 第4行 后面, 添加了内容, 对应 note2 的 第6到8行
4a6,8
> 40
> 41
> 42
# 为了变成 note2, note1 的 第5行 后面, 添加了内容, 对应 note2 的 第10行
5a10
> 51
5. 场景4: 变化 - 删除
概述
- 稍微麻烦点的变化
- 主要是 不好理解
文本
note1
1
10
2
3
4
40
41
42
5
51
note2
1
2
3
4
5
命令
# 也可以直接用上一个场景的文件, 命令是 diff note2 note1
> diff note1 note2
结果
# 为了变成note2, note1 的 第2行 被删除了, 被删除的行, 本该在 note2 第1行 的后面
2d1
< 10
# 为了变成note2, note1 的 第6到8行 被删除了, 被删除的行, 本该在 note2 第4行 的后面
6,8d4
< 40
< 41
< 42
# 为了变成note2, note1 的 第10行 被删除了, 被删除的行, 本该在 note2 第5行 的后面
10d5
< 51
6. 场景5: 并列模式
概述
- 并列展示内容
文本
- 同 场景1
命令
# 还可以加 选项 -W <宽度> 来调整宽度
> diff -y note1 note2
结果
# | 两边有不同
1 | 10
2 2
3 | 30
4 | 40
5 | 50
6 6
7 | 70
# > 只有 note2 有的内容
> 71
> 72
8 8
9 | 90
# < 只有 note1 有的内容
0 <
7. 场景6: -c 输出
概述
- 另一种 style, 但我不知道它叫什么
文本
- 同 场景1
命令
> diff -c note1 note2
结果
*** note1 2020-01-12 00:32:18.418000000 +0800
--- note2 2020-01-12 00:32:24.255000000 +0800
***************
*** 1,10 ****
! 1
2
! 3
! 4
! 5
6
! 7
8
! 9
! 0
--- 1,11 ----
! 10
2
! 30
! 40
! 50
6
! 70
! 71
! 72
8
! 90
8. 场景7: -u 输出
概述
- 另一种 style, 但我不知道它叫什么
文本
- 同 场景1
命令
> diff -u note1 note2
结果
# 感觉并不是很友好的样子
--- note1 2020-01-12 00:32:18.418000000 +0800
+++ note2 2020-01-12 00:32:24.255000000 +0800
@@ -1,10 +1,11 @@
-1
+10
2
-3
-4
-5
+30
+40
+50
6
-7
+70
+71
+72
8
-9
-0
+90
ps
ref
后续
- git diff
- vimdiff
- 其他
感觉
- 其实 diff 的知识点不多
- 但是为啥我两句三句, 就扯了这么长一篇?
- 但愿能成功入门吧
- 其实 diff 的知识点不多
Linux - Shell - diff的更多相关文章
- 老李分享:《Linux Shell脚本攻略》 要点(一)
老李分享:<Linux Shell脚本攻略> 要点(一) 第一章:Shell起步基础 1.变量:在bash中,每一个变量的值都是字符串.无论你给变量赋值时,有没有使用引号,值都会以字符 ...
- Linux Shell常用shell命令
Linux Shell常用shell命令 一.文件.目录操作命令 1.ls命令 功能:显示文件和目录的信息 ls 以默认方式显示当前目录文件列表 ls -a 显示所有文件包括隐藏文件 ls -l 显示 ...
- 《Linux Shell 脚本攻略》读书笔记
本书主要讲解一些linux shell命令的用法,讲解一些shell的奇技淫巧. 第一章 小试牛刀 主要介绍一些基本shell指令 终端打印:echo.printf 别名:alias 终端处理工具:t ...
- linux shell脚本攻略笔记
前一阵子系统学习了下<linux shell脚本攻略>这本书.在此记录下自己的学习笔记 1. 输出颜色字符 echo -e "\e[1:41m" 1表示背景色 2 ...
- Linux Shell编程与编辑器使用详解
<Linux Shell编程与编辑器使用详解> 基本信息 作者: 刘丽霞 杨宇 出版社:电子工业出版社 ISBN:9787121207174 上架时间:2013-7-22 出版日期:201 ...
- LINUX SHELL脚本攻略笔记[速查]
Linux Shell脚本攻略笔记[速查] 资源 shell script run shell script echo printf 环境变量和变量 pgrep shell数学运算 命令状态 文件描述 ...
- linux shell 中的sleep命令
开始还以为是这样的语法: sleep(1), 后面发现是: linux shell 中的sleep命令 分类: LINUX 在有的shell(比如linux中的bash)中sleep还支持睡眠(分,小 ...
- Linux shell脚本编程(三)
Linux shell脚本编程 流程控制: 循环语句:for,while,until while循环: while CONDITION; do 循环体 done 进入条件:当CONDITION为“真” ...
- Linux shell脚本编程(二)
Linux shell脚本编程(二) 练习:求100以内所有偶数之和; 使用至少三种方法实现; 示例1: #!/bin/bash # declare -i sum=0 #声明一个变量求和,初始值为0 ...
随机推荐
- float浮动以及案例演示
浮动元素会影响后边的元素,但不会影响前边的元素 清除浮动: 方法一:在浮动元素后面添加一个空元素 <!DOCTYPE html> <html lang="en"& ...
- 获取redis实例绑定cpu的情况
redis是一个单线模型的nosql类型的数据库,而目前接触到的服务器大都是多核的,比如8c,16c,32c,64c等等.为了充分利用主机,在一台主机上必然会部署多个redis实例,默认情况cpu会随 ...
- linux--工具进阶
linux学习 看完了基础篇,下面来看进阶篇 我好想哭看这的时候,好多只是听说过,但完全没有试过,感觉自己懂得有点少,就是缺乏一些知识储备,也就是必须知道了某些或学过了某些知识才适合来看这一部分,看得 ...
- 纪中23日c组T2 2159. 【2017.7.11普及】max 洛谷P1249 最大乘积
纪中2159. max 洛谷P1249 最大乘积 说明:这两题基本完全相同,故放在一起写题解 纪中2159. max (File IO): input:max.in output:max.out 时间 ...
- JAVA成长之路SpringCloud脚印(一)
从即日起开始学习SpringCloud,在这里记录下学习过程,共勉,欢迎指正. 环境:IDEA2019.3.3.JAVA13 一.spring cloud简介 spring cloud 为开发人员提供 ...
- 洛谷题解 P1134 【阶乘问题】
原题传送门 题目描述 也许你早就知道阶乘的含义,N阶乘是由1到N相乘而产生,如: 12!=1×2×3×4×5×6×7×8×9×10×11×12=479,001,600 12的阶乘最右边的非零位为6. ...
- ES6数组去重方法
Set实例的方法分为两大类:操作方法(用于操作数据)和遍历方法(用于遍历成员),操作方法有:add(value).delete(value).has(value).clear():遍历方法有:keys ...
- Python 文件&异常 初学者笔记
文件 读取整个文件 with open('pi_30_digits.txt') as file_object :#Python在当前执行文件目录寻找指定文件#filename = 文件的绝对路径或相对 ...
- 手写mybatis框架笔记
MyBatis 手写MyBatis流程 架构流程图 封装数据 封装到Configuration中 1.封装全局配置文件,包含数据库连接信息和mappers信息 2.封装*mapper.xml映射文件 ...
- (jsp+servlet+javabean )MVC架构
MVC是三个单词的缩写,这三个单词分别为:模型.视图和控制. 使用的MVC的目的:在于将M和V的实现代码分离,从而使同一个程序可以使用不同的表现形式.比如Windows系统资源管理器文件夹内容的显示方 ...