如何区分一个文件到Git中的任意版本?
如何将一个文件(比如说pom.xml
)从主分支转换为Git中的任意旧版本?
你可以做:
git diff master~20:pom.xml pom.xml
…通过第一个父节点比较你当前的pom.xml
和master
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>
例如:
请注意右上angular的“上一个”和“下一个”链接,使您可以浏览提交中的所有文件。
这只适用于特定的提交,不适用于任何两个任意版本之间的比较。
git diff master~20 -- pom.xml
如果你不在主分支也工作。