在Git中,如何在同一个分支(例如master)上的两个不同提交(不是连续的)之间比较相同的文件?

我正在寻找一个类似于Visual SourceSafe (VSS)或Team Foundation Server (TFS)中的比较功能。 在Git中可以吗?


当前回答

你也可以比较两个不同版本的文件,如下所示:

Git diff <revision_1>:<file_1> <revision_2>:<file_2>

其他回答

如果你有几个文件或目录,想要比较非连续提交,你可以这样做:

创建临时分支(本例中为“revision”)

git checkout -b revision

倒回到第一个提交目标

git reset --hard <commit_target>

对那些有兴趣的人挑刺

git cherry-pick <commit_interested> ...

应用比较

git diff <commit-target>^

当你完成时

git branch -D revision

查看$ git log,复制两次不同提交的SHA-1 ID,并使用这些ID执行git diff命令。例如:

$ git diff (sha-id-one) (sha-id-two)

这只是另一种使用Git的方式……

git difftool HEAD HEAD@{N} /PATH/FILE.ext

如果你想对多个文件进行diff,使用@mipadi指定的方法:

例如,HEAD和master之间的差异,找到所有的。coffee文件:

git diff master..HEAD -- `find your_search_folder/ -name '*.coffee'`

这将递归搜索your_search_folder/所有的.coffee文件,并在它们和它们的主版本之间做出区别。

其他的回答都比较完整,给它们点赞吧。 这只是为了记住,您可以避免知道最近提交的id。通常,我将自己设置在我想要比较的分支中,并运行diff工具,知道旧的提交uid(你可以使用其他符号):

git checkout master
git difftool 6f8bba my/file/relative/path.py

另外,检查这里的其他响应来设置你想要git打开的工具来比较文件: 使用.gitconfig配置diff工具 要了解更多关于difftool的知识,请访问difftool文档