如何区分一个文件到Git中的任意版本?

如何将一个文件(比如说pom.xml )从主分支转换为Git中的任意旧版本?

你可以做:

 git diff master~20:pom.xml pom.xml 

…通过第一个父节点比较你当前的pom.xmlmaster 20版本之前的版本。 当然,你可以使用提交的对象名称(SHA1sum)或其他许多指定修订版本的方法来replacemaster〜20。

请注意,这实际上是将旧的pom.xml与工作树中的版本进行比较,而不是在master提交的版本。 如果你想这样做,那么你可以做下面的事情:

 git diff master~20:pom.xml master:pom.xml 
 git diff <revision> <path> 

例如:

 git diff b0d14a4 foobar.txt 

如果你想看到单个文件的最后一次提交的区别,你可以这样做:

 git log -p -1 filename 

这会给你在git文件的差异,不是比较你的本地文件。

要查看上次提交中的文件中发生了什么变化:

 git diff HEAD~1 path/to/file. 

您可以将数字(〜1)更改为您想要与之区分的第n个提交。

git diff -w HEAD origin / master path / to / file

如果两个提交都不是你的HEAD,那么bash的大括号扩展certificate是非常有用的,特别是如果你的文件名很长,上面的例子:

 git diff master~20:pom.xml master:pom.xml 

会成为

 git diff {master~20,master}:pom.xml 

更多关于bash的Brace扩展 。

通用语法:

 $git diff oldCommit..newCommit -- **FileName.xml > ~/diff.txt 

所有名为“FileName.xml”的文件在你的仓库中的任何地方。

注意“ – ”和“**”之间的空格

回答你的问题:

 $git checkout master $git diff oldCommit..HEAD -- **pom.xml or $git diff oldCommit..HEAD -- relative/path/to/pom.xml 

与git一样,您可以使用标签/ sha1 /“HEAD ^”来标识提交。

在Ubuntu上使用git 1.9.1进行testing。

对于有兴趣从GitHub做同样的事情,请参阅比较提交的时间 。

对于比较5当前的一个,无论是在master ,只是简单地做:

 git diff master~5:pom.xml master:pom.xml 

你也可以参考提交散列号,例如,如果散列号是x110bd64 ,你可以做这样的事情来看看不同之处:

 git diff x110bd64 pom.xml 

如果你需要比较一个单独的文件,例如你可以这样做

 git diff stash@{0} -- path/to/file 

如果您正在寻找特定提交的diff,并且想要使用github UI而不是命令行(假设您想将其链接到其他人),则可以执行以下操作:

 https://github.com/<org>/<repo>/commit/<commit-sha>/<path-to-file> 

例如:

https://github.com/grails/grails-core/commit/02942c5b4d832b856fbc04c186f1d02416895a7e/grails-test-suite-uber/build.gradle

请注意右上angular的“上一个”和“下一个”链接,使您可以浏览提交中的所有文件。

这只适用于特定的提交,不适用于任何两个任意版本之间的比较。

 git diff master~20 -- pom.xml 

如果你不在主分支也工作。