在最后一次提交后,我修改了工作副本中的一堆文件,但我想撤消对其中一个文件的更改,如将其重置为与最近一次提交相同的状态。

然而,我只想撤消仅对该文件的工作副本更改,而不做其他更改。

我该怎么做?


当前回答

我使用SHA id恢复文件,我所做的是git checkout<SHA hash id><文件名>

其他回答

git checkout a3156ae4913a0226caa62d8627e0e9589b33d04c -p */SearchMaster.jsp

细分:a3156ae4913a0226caa62d8627e0e9589b33d04c=这是提交的哈希值。这是我自己的分支(而不是主分支)。

-p标志是路径。

*/SearchMaster.jsp是文件名。

这是撤消同一或多个文件夹(或目录)中多个特定文件中的本地更改所需的命令的答案。这回答了用户有多个文件但用户不想撤消所有本地更改的问题:

如果您有一个或多个文件,可以将相同的命令(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 diff --stat HEAD^...HEAD | \
fgrep filename_snippet_to_revert | cut -d' ' -f2 | xargs git checkout HEAD^ --
git commit -a --amend

我通过gitbash完成了:

(使用“gitcheckout--<file>…”放弃工作目录中的更改)

Git状态。[所以我们看到一个文件被修改了。]git checkout--index.html[我已在index.html文件中更改:git状态[现在这些更改已删除]

如果您的文件已经暂存(在编辑文件后执行gitadd等操作时发生),则取消对更改的暂存。

Use

git reset HEAD <file>

然后

git checkout <file>

如果尚未暂存,请使用

git checkout <file>