- 概述
- 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 的知识点不多