在最后一次提交后,我修改了工作副本中的一堆文件,但我想撤消对其中一个文件的更改,如将其重置为与最近一次提交相同的状态。
然而,我只想撤消仅对该文件的工作副本更改,而不做其他更改。
我该怎么做?
在最后一次提交后,我修改了工作副本中的一堆文件,但我想撤消对其中一个文件的更改,如将其重置为与最近一次提交相同的状态。
然而,我只想撤消仅对该文件的工作副本更改,而不做其他更改。
我该怎么做?
当前回答
如果您尚未推送或以其他方式共享您的承诺:
git diff --stat HEAD^...HEAD | \
fgrep filename_snippet_to_revert | cut -d' ' -f2 | xargs git checkout HEAD^ --
git commit -a --amend
其他回答
我使用SHA id恢复文件,我所做的是git checkout<SHA hash id><文件名>
如果您想撤消对该文件的上一次提交更改,可以尝试以下操作:
git checkout branchname^ filename
这将按上次提交前的状态签出文件。如果您想再提交几次,请使用branchname~n表示法。
对我来说,只有这个有效
git checkout -p filename
如果已经提交,则可以还原文件的更改并再次提交,然后用上次提交来压缩新的提交。
如果您的文件已经暂存(在编辑文件后执行gitadd等操作时发生),则取消对更改的暂存。
Use
git reset HEAD <file>
然后
git checkout <file>
如果尚未暂存,请使用
git checkout <file>