在最后一次提交后,我修改了工作副本中的一堆文件,但我想撤消对其中一个文件的更改,如将其重置为与最近一次提交相同的状态。

然而,我只想撤消仅对该文件的工作副本更改,而不做其他更改。

我该怎么做?


当前回答

对我来说,只有这个有效

git checkout -p filename

其他回答

只需使用

git checkout filename

这将用当前分支的最新版本替换文件名。

警告:您的更改将被丢弃-不保留备份。

git checkout a3156ae4913a0226caa62d8627e0e9589b33d04c -p */SearchMaster.jsp

细分:a3156ae4913a0226caa62d8627e0e9589b33d04c=这是提交的哈希值。这是我自己的分支(而不是主分支)。

-p标志是路径。

*/SearchMaster.jsp是文件名。

如果您想撤消对该文件的上一次提交更改,可以尝试以下操作:

git checkout branchname^ filename

这将按上次提交前的状态签出文件。如果您想再提交几次,请使用branchname~n表示法。

如果已经提交,则可以还原文件的更改并再次提交,然后用上次提交来压缩新的提交。

git checkout <commit> <filename>

我今天使用这个是因为我意识到我的收藏夹在几次提交之前被覆盖了,当我升级到drupal 6.10时,所以我不得不把它拿回来。以下是我所做的:

git checkout 088ecd favicon.ico