在最后一次提交后,我修改了工作副本中的一堆文件,但我想撤消对其中一个文件的更改,如将其重置为与最近一次提交相同的状态。
然而,我只想撤消仅对该文件的工作副本更改,而不做其他更改。
我该怎么做?
在最后一次提交后,我修改了工作副本中的一堆文件,但我想撤消对其中一个文件的更改,如将其重置为与最近一次提交相同的状态。
然而,我只想撤消仅对该文件的工作副本更改,而不做其他更改。
我该怎么做?
当前回答
如果您尚未推送或以其他方式共享您的承诺:
git diff --stat HEAD^...HEAD | \
fgrep filename_snippet_to_revert | cut -d' ' -f2 | xargs git checkout HEAD^ --
git commit -a --amend
其他回答
git还原文件
请参阅此重复答案(确保向下滚动到2020更新):https://stackoverflow.com/a/31281748/12763497
如果您想撤消对该文件的上一次提交更改,可以尝试以下操作:
git checkout branchname^ filename
这将按上次提交前的状态签出文件。如果您想再提交几次,请使用branchname~n表示法。
Git 2.23引入了一个还原来实现这一点,我认为,这是为了让这些问题的答案变得简单明了。
git restore [--] <pathspec>...
与往常一样,可能需要--,但当文件名以破折号开头时。(此处不可能与分支名称混淆,因为恢复的范围不包括分支,而不是全部检出)
要完成还原,还可以使用--staged还原暂存文件,并使用--source=<tree>从与HEAD不同的提交还原。
git checkout a3156ae4913a0226caa62d8627e0e9589b33d04c -p */SearchMaster.jsp
细分:a3156ae4913a0226caa62d8627e0e9589b33d04c=这是提交的哈希值。这是我自己的分支(而不是主分支)。
-p标志是路径。
*/SearchMaster.jsp是文件名。
只需使用
git checkout filename
这将用当前分支的最新版本替换文件名。
警告:您的更改将被丢弃-不保留备份。