我有一个脚本,在一个分支中运行良好,而在另一个分支上却被破坏。我想并排看两个版本,看看有什么不同。有办法做到这一点吗?

要清楚的是,我不是在寻找比较工具(我使用Beyond compare)。我正在寻找一个Gitdiff命令,该命令允许我将主版本与当前分支版本进行比较,以查看发生了什么变化。我没有在合并或其他事情中。我只是想说

git diff mybranch/myfile.cs master/myfile.cs

当前回答

在我的情况下,我使用以下命令:

git diff <branch name> -- <file path + file name>

此命令可以帮助您比较两个不同分支中的同一文件。

其他回答

为了比较Git Bash中的两个文件,您需要使用以下命令:

git diff <Branch name>..master -- Filename.extension

该命令将在Bash本身中显示两个文件之间的差异。

有两种方案可以比较文件:

场景1:比较远程分支处的文件(两个分支都应存在于远程存储库中)

场景2:将本地文件(在本地工作区副本)与远程存储库中的文件进行比较。

逻辑很简单。如果您向diff提供两个分支名称,它将始终比较远程分支,如果您只提供一个分支名称的话,它将总是将本地工作副本与远程存储库(您提供的)进行比较。您可以使用范围提供远程存储库。

例如,签出分支:

git checkout branch1
git diff branch2 [filename]

在这种情况下,如果您提供文件名,它会将文件名的本地副本与名为“branch2”的远程分支进行比较。

git diff branch1 branch2 [filename]

在本例中,它将比较名为“branch1”和“branch2”的远程分支的文件名

git diff ..branch2 [filename]

在本例中,它还将比较名为“branch1”和“branch2”的远程分支的文件名。所以,和上面一样。但是,如果您刚刚从另一个分支创建了一个分支,比如说“master”,并且您当前的分支在远程存储库中不存在,那么它将比较远程“master”和远程“branch2”。

对于Visual Studio代码,我强烈建议扩展:

Git历史差异文档

您可以使用它在文件之间甚至分支之间进行两次比较!

在控制台中,您可以简单地使用以下命令:

git diff <Your_Branch> <Branch_To_Compare_With> -- myfile.cs

使用提交哈希如下:

git diff <hash1> <hash2> <filename>

其中hash1可以是来自任何分支的任何提交,hash2也是如此。

关于这些不同的比较方法,还有一个有趣的点:我想将当前分支中的文件与另一个分支中的相同文件进行比较。如果我使用

git difftool otherbranch.. filespec

我最后比较了两个文件,它们实际上在我的临时文件夹中。但是,如果我使用

git difftool otherbranch filespec

我最终将临时文件夹中的一个文件(其他分支上的版本)与Git文件夹中的实际文件进行了比较,这a)让我更容易分辨哪个是哪个,b)意味着我可以使用diff工具(在我的例子中是Beyond Compare 4)将更改从其他分支复制到当前分支。