通常,要放弃对文件的更改,您将执行以下操作:
git checkout -- <file>
如果我想要放弃的更改是删除文件,该怎么办?上面的代码行会给出一个错误:
error: pathspec '<file>' did not match any file(s) known to git.
哪个命令可以在不撤消其他更改的情况下恢复单个文件?
加分点:另外,如果我想放弃的更改是添加文件怎么办?我也想知道如何取消这种更改。
发布于 2012-03-07 04:46:26
假设您想要撤消git rm <file>
或rm <file>
的效果,然后是git add -A
或类似的效果:
# this restores the file status in the index
git reset -- <file>
# then check out a copy from the index
git checkout -- <file>
要撤消git add <file>
,上面的第一行就足够了,假设您还没有提交。
发布于 2012-03-07 04:37:34
这两个问题都在git status
中得到了回答。
要取消转储添加新文件,请使用git rm --cached filename.ext
# Changes to be committed:
# (use "git rm --cached <file>..." to unstage)
#
# new file: test
要取消阶段删除文件,请使用git reset HEAD filename.ext
# Changes to be committed:
# (use "git reset HEAD <file>..." to unstage)
#
# deleted: test
另一方面,git checkout --
从不取消升级,它只会丢弃未升级的更改。
发布于 2017-08-10 22:19:06
如果已暂存并提交,则执行以下操作将重置该文件:
git reset COMMIT_HASH file_path
git checkout COMMIT_HASH file_path
git add file_path
这将适用于之前多次提交的删除。
https://stackoverflow.com/questions/9591407
复制相似问题