在最后一次提交后,我修改了工作副本中的一堆文件,但我想撤消对其中一个文件的更改,如将其重置为与最近一次提交相同的状态。
然而,我只想撤消仅对该文件的工作副本更改,而不做其他更改。
我该怎么做?
在最后一次提交后,我修改了工作副本中的一堆文件,但我想撤消对其中一个文件的更改,如将其重置为与最近一次提交相同的状态。
然而,我只想撤消仅对该文件的工作副本更改,而不做其他更改。
我该怎么做?
当前回答
只需使用
git checkout filename
这将用当前分支的最新版本替换文件名。
警告:您的更改将被丢弃-不保留备份。
其他回答
您可以使用
git checkout -- file
您可以不使用--(如nimrodm所建议的),但如果文件名看起来像分支或标记(或其他修订标识符),则可能会混淆,因此最好使用--。
您还可以检出文件的特定版本:
git checkout v1.2.3 -- file # tag v1.2.3
git checkout stable -- file # stable branch
git checkout origin/master -- file # upstream master
git checkout HEAD -- file # the version from the most recent commit
git checkout HEAD^ -- file # the version before the most recent commit
git还原文件
请参阅此重复答案(确保向下滚动到2020更新):https://stackoverflow.com/a/31281748/12763497
我使用SHA id恢复文件,我所做的是git checkout<SHA hash id><文件名>
只需使用
git checkout filename
这将用当前分支的最新版本替换文件名。
警告:您的更改将被丢弃-不保留备份。
如果您尚未推送或以其他方式共享您的承诺:
git diff --stat HEAD^...HEAD | \
fgrep filename_snippet_to_revert | cut -d' ' -f2 | xargs git checkout HEAD^ --
git commit -a --amend