431

我在 branch-X 上,并在其上添加了几个提交。我想看看 MASTER 和我所在的分支在提交方面的所有差异。我可以做一个

git checkout master
git log

然后一个

git checkout branch-X
git log

并在视觉上区分这些,但我希望有一种更简单、更不容易出错的方法。

4

10 回答 10

836

你可以很容易地做到这一点

git log master..branch-X

这将向您显示 branch-X 具有但 master 没有的提交。

于 2012-12-20T04:42:39.467 回答
387

您可以获得一个非常好的视觉输出,说明您的分支与此有何不同

git log --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr)%Creset' --abbrev-commit --date=relative master..branch-X
于 2012-12-20T04:43:48.377 回答
127

我认为这是选择和上下文的问题。我更喜欢使用

git log origin/master..origin/develop --oneline --no-merges

它将在开发中显示不在 master 分支中的提交。

如果您想查看实际修改了哪些文件,请使用

git diff --stat origin/master..origin/develop --no-merges

如果您不指定参数,它将显示完整的差异。如果您想查看视觉差异,请安装meld在 linux 或WinMergewindows 上。确保它们是默认的 difftools 。然后使用类似的东西

git difftool -y origin/master..origin/develop --no-merges

如果您想将其与当前分支进行比较。使用 HEAD 而不是使用分支名称更方便:

git fetch
git log origin/master..HEAD --oneline --no-merges

它将向您显示即将合并的所有提交

于 2015-11-02T23:49:55.043 回答
24

我建议以下内容来查看“提交”中的差异。对于对称差异,使用反转的 args 重复命令:

git cherry -v master [your branch, or HEAD as default]
于 2015-11-17T00:36:29.000 回答
16

如果您使用的是 Linux,gitg则可以非常快速地以图形方式进行操作。

如果您坚持使用命令行,则可以使用:

git log --oneline --decorate

为了git log更好地默认设置,我通常设置这些全局首选项:

git config --global log.decorate true
git config --global log.abbrevCommit true
于 2012-12-20T04:55:09.613 回答
9

如果你想使用 gitk:

gitk master..branch-X

它有一个不错的老式 GUI

于 2015-08-26T08:37:43.973 回答
5

不是完美的答案,但对使用 Github 的人来说效果更好:

在此处输入图像描述

转到您的仓库:Insights -> Network

于 2017-09-28T08:15:43.270 回答
3

我使用了一些答案并找到了一个适合我的情况(确保所有任务都在发布分支中)。

其他方法也可以,但我发现它们可能会添加我不需要的行,例如没有任何价值的合并提交。

git fetch
git log origin/master..origin/release-1.1 --oneline --no-merges

或者你可以将你的电流与主人进行比较

git fetch
git log origin/master..HEAD --oneline --no-merges

git fetch是否可以确保您使用的是更新的信息。

这样,每个提交都将在一行中,您可以将其复制/粘贴到文本编辑器中,然后开始将任务与将要合并的提交进行比较。

于 2019-06-24T17:53:02.447 回答
3

如果要根据提交消息进行比较,可以执行以下操作:

git fetch
git log --oneline origin/master | cut -d' ' -f2- > master_log
git log --oneline origin/branch-X | cut -d' ' -f2- > branchx_log
diff <(sort master_log) <(sort branchx_log)
于 2019-08-21T05:24:12.200 回答
0
#! /bin/bash
if ((2==$#)); then
  a=$1
  b=$2
  alog=$(echo $a | tr '/' '-').log
  blog=$(echo $b | tr '/' '-').log
  git log --oneline $a > $alog
  git log --oneline $b > $blog
  diff $alog $blog
fi

做出贡献是因为它允许 a 和 b 日志在视觉上并排地进行比较,如果你有一个视觉差异工具的话。将末尾的 diff 命令替换为启动可视差异工具的命令。

于 2016-10-08T13:32:06.950 回答