在最后一次提交后,我修改了工作副本中的一堆文件,但我想撤消对其中一个文件的更改,如将其重置为与最近一次提交相同的状态。
然而,我只想撤消仅对该文件的工作副本更改,而不做其他更改。
我该怎么做?
在最后一次提交后,我修改了工作副本中的一堆文件,但我想撤消对其中一个文件的更改,如将其重置为与最近一次提交相同的状态。
然而,我只想撤消仅对该文件的工作副本更改,而不做其他更改。
我该怎么做?
当前回答
我通过gitbash完成了:
(使用“gitcheckout--<file>…”放弃工作目录中的更改)
Git状态。[所以我们看到一个文件被修改了。]git checkout--index.html[我已在index.html文件中更改:git状态[现在这些更改已删除]
其他回答
git checkout <commit> <filename>
我今天使用这个是因为我意识到我的收藏夹在几次提交之前被覆盖了,当我升级到drupal 6.10时,所以我不得不把它拿回来。以下是我所做的:
git checkout 088ecd favicon.ico
这是撤消同一或多个文件夹(或目录)中多个特定文件中的本地更改所需的命令的答案。这回答了用户有多个文件但用户不想撤消所有本地更改的问题:
如果您有一个或多个文件,可以将相同的命令(gitcheckout--file)应用于通过列出这些文件的每个位置空格如下:
git checkout -- name1/name2/fileOne.ext nameA/subFolder/fileTwo.ext
注意name1/name2/fileOne.ext nameA/subFolder/fileTwo.ext之间的空格
对于同一文件夹中的多个文件:
如果您碰巧需要放弃对在特定目录下,按如下方式使用git签出:
git checkout -- name1/name2/*
上面的星号可以撤消name1/name2下该位置的所有文件。
同样,以下操作可以撤消所有文件中的更改多个文件夹:
git checkout -- name1/name2/* nameA/subFolder/*
再次注意name1/name2/*nameA/subFolder/*之间的空格在上面
注意:name1、name2、nameA、subFolder-所有这些示例文件夹名称都表示有问题文件所在的文件夹或包。
Git 2.23引入了一个还原来实现这一点,我认为,这是为了让这些问题的答案变得简单明了。
git restore [--] <pathspec>...
与往常一样,可能需要--,但当文件名以破折号开头时。(此处不可能与分支名称混淆,因为恢复的范围不包括分支,而不是全部检出)
要完成还原,还可以使用--staged还原暂存文件,并使用--source=<tree>从与HEAD不同的提交还原。
如果您想撤消对该文件的上一次提交更改,可以尝试以下操作:
git checkout branchname^ filename
这将按上次提交前的状态签出文件。如果您想再提交几次,请使用branchname~n表示法。
如果您尚未推送或以其他方式共享您的承诺:
git diff --stat HEAD^...HEAD | \
fgrep filename_snippet_to_revert | cut -d' ' -f2 | xargs git checkout HEAD^ --
git commit -a --amend