我有一个脚本,在一个分支中运行良好,而在另一个分支上却被破坏。我想并排看两个版本,看看有什么不同。有办法做到这一点吗?
要清楚的是,我不是在寻找比较工具(我使用Beyond compare)。我正在寻找一个Gitdiff命令,该命令允许我将主版本与当前分支版本进行比较,以查看发生了什么变化。我没有在合并或其他事情中。我只是想说
git diff mybranch/myfile.cs master/myfile.cs
我有一个脚本,在一个分支中运行良好,而在另一个分支上却被破坏。我想并排看两个版本,看看有什么不同。有办法做到这一点吗?
要清楚的是,我不是在寻找比较工具(我使用Beyond compare)。我正在寻找一个Gitdiff命令,该命令允许我将主版本与当前分支版本进行比较,以查看发生了什么变化。我没有在合并或其他事情中。我只是想说
git diff mybranch/myfile.cs master/myfile.cs
当前回答
有两种方案可以比较文件:
场景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”。
其他回答
有多种方法可以比较来自两个不同分支的文件:
选项1:如果要将文件从n个特定分支与另一个特定分支进行比较:git diff branch1名称branch2名称路径/to/file例子:git diff mybranch/myfile.cs mysecondbranch/mdfile.cs在本例中,您将“mybranch”分支中的文件与“mysecondbranch”分支中的文件。选项2:简单方法:git diff branch1:文件branch2:文件例子:git diff mybranch:myfile.cs mysecondbranch:m:file.cs此示例与选项1类似。选项3:如果要将当前工作目录与某个分支进行比较:git差异。。someBranch路径/to/file例子:git差异。。主myfile.cs在本例中,您将实际分支中的文件与主分支中的文件。
最好的方法是按以下方式使用gitdiff:
git diff<source_branch><target_branch>--文件路径
它将检查这些分支中文件之间的差异。查看本文,了解有关Git命令及其工作方式的更多信息。
为了比较Git Bash中的两个文件,您需要使用以下命令:
git diff <Branch name>..master -- Filename.extension
该命令将在Bash本身中显示两个文件之间的差异。
我同意达尔比克的回答。如果希望将diff写入diff文件以进行代码检查,请使用以下命令。
git diff branch master -- filepath/filename.extension > filename.diff --cached
我只需执行git diff branch1 branch2路径/to/file
这将检查文件之间的差异。分支1的变化将显示为红色。分支2的变化将为绿色。
假设分支1是过去,分支2是未来。您可以通过反转diff:gitdiffbranch2-branch1中分支的顺序来反转这一点