前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >git diff 的一个妙用

git diff 的一个妙用

作者头像
王云峰
发布2023-10-23 10:40:06
2100
发布2023-10-23 10:40:06
举报

1. git diff 常规用法

git diff 可以用来比较在git仓库中的两次提交或两个文件的diff,常见用法如下:

代码语言:javascript
复制
# 显示当前代码与最新commit的代码之间的差别
git diff

# 显示暂存(也就是已经git add 但还没有git commit)的代码提交
git diff --staged

# 显示当前代码与<commit-id>时代码的区别
git diff <commit-id> 

# 显示暂存代码与<commit-id>时代码的区别
git diff --staged <commit-id> 

# 显示两次commit-id之间的代码区别
git diff <commit-id1> <commit-id2>  

# 显示当前分支与 branch1 分支上的代码区别
git diff <branch1>

# 显示两个分支上的代码之间的区别
git diff <branch1> <branch2>

所有上述命令后面都可以加一个目录或文件路径来只显示这个目录或文件中的区别:

代码语言:javascript
复制
git diff /path/to/folder

git diff /path/to/file.py

# 也可用git的参数终止符号--,避免文件名和参数重名时将文件名解析为参数
git diff --  /path/to/file.py

2. git diff 妙用

git diff 有一个选项--no-index ,可以用来不在git仓库中的两个文件或目录。 --no-index的git帮助文档中说明如下:

代码语言:javascript
复制
git diff [<options>] --no-index [--] <path> <path>
This form is to compare the given two paths on the filesystem. You can omit the --no-index option when running the command in a working tree controlled by Git and at least one of the paths points outside the working tree, or when running the command outside a working tree controlled by Git. This form implies --exit-code.

说明它可以用来比较两个给定的路径。

那为什么要用git diff 来比较非git仓库里面的两个路径呢,直接用Linux和Mac上自带的diff 命令不好吗?

git diff 相比diff 的优势是它能生成以+- 开头的diff结果,红色表示删去,绿色表示添加,因此能很直观地看出增加和删除了哪些地方,而diff给出来的是黑色的代码差别,展示很不直观。

另外git diff的结果可以写入文件,粘贴到Markdown文件中,大部分 Markdown 渲染器都能够识别diff块,比较好地渲染出diff结果。

实际操作中,需要在一个git仓库目录中来执行git diff --no-index,例如比较两个文件:

代码语言:javascript
复制
git diff --no-index ~/a.py ~/b.py

比较两个目录:

代码语言:javascript
复制
git diff --no-index ~/folder-a ~/folder-b

One More Thing

其实我之前写过一个比较两个目录的Python工具dompare(名字含义是directory compare),通过执行一条命令得到得到两个目录中文件的diff,并且保存到HTML网页中打开浏览器进行展示。感兴趣的小伙伴可以玩一玩。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2023-06-30,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. git diff 常规用法
  • 2. git diff 妙用
  • One More Thing
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档